AWS MySQL 升级(二)—— MySQL API逻辑同步升级操作步骤

news2024/9/23 1:28:25

       接上一篇 AWS MySQL 升级(一)—— 对比各类方案及原理_pg跨库查询-CSDN博客,由于操作步骤太多,单独拆出来一份。

零、 预检查

  • 主库event_scheduler参数,应该为0

show variables like '%event_scheduler%';

  • binlog保留时长,不低于24

call mysql.rds_show_configuration;

  • 是否已建好同步用户

select user,host from mysql.user;

  • 主从库白名单是否一致
  • 参数组、选项组是否一致
  • 业务是否有使用从库
  • 是否有中美同步链路

一、 创建只读副本

选择待升级实例 -> 操作 -> 创建只读副本

新库取名(后续应用将使用该连接串)

选择创建只读副本,等待创建完成即可,大库耗时较长,建议提前操作。

二、 升级新只读副本

参考上篇本地升级步骤

三、 新只读副本提升为主库

  • event_scheduler 开始的时候一定要设置为0,如果需要,等版本升级完,再修改为1
  • 修改binlog retention period ,在源库和升级库上操作
call mysql.rds_show_configuration;
call mysql.rds_set_configuration('binlog retention hours', 24);
  • 停复制进程,记录 Master_Log_File 和 Exec_Master_Log_Pos,建议执行2次
CALL mysql.rds_stop_replication;
SHOW SLAVE STATUS\G

  • 高版本DB提升为主库

注意如果DB处于存储优化阶段,无法提升为主库

提升时间为1分钟左右

四、 配置逻辑同步

  • 在源主库上创建复制用户
CREATE USER 'repl'@'%' IDENTIFIED BY 'xxxx';
GRANT REPLICATION CLIENT, REPLICATION SLAVE ON *.* TO 'repl'@'%';
  • 在提升的主库上通过API设置主从复制

源库的IP地址,需要ping 源库的连接串获取,并且将此ip添加到新库的安全组中。

call mysql.rds_set_external_master(
'源库的IP地址',
3306,
'repl',
'xxx',
'mysql-bin-changelog.001109',
120,
0);

CALL mysql.rds_start_replication;
SHOW SLAVE STATUS\G

五、为升级后的DB创建从库

参考第一步

六、 为升级后的DB配置监控及标签

参考创建SOP

七、 配置nginx至旧主库

将Nginx中连接串配置为旧主库连接串,重启Nginx

八、 业务切换连接至Nginx

业务操作

DBA检查连接切换情况,是否都已切换至通过Nginx代理连接

show procsslist;

登录检查业务是否仍有连接

select db,user,host from information_schema.processlist where host like '10.0.xx.xx%';

九、检查主从同步延迟情况

show slave status\G

务必执行。若存在延迟或报错时执行切换,将导致切换后数据不一致。

十、 配置nginx至新主库

十一、 业务切换连接至新主库

业务修改连接串至新主库,DBA检查连接情况

登录新主库检查,业务是否已切换至新主库

select db,user,host from information_schema.processlist where host not like '10.0.xx.xx%';

登录旧主库检查,业务是否仍有连接

select db,user,host from information_schema.processlist where host not like '10.0.xx.xx%';

十二、修改从库连接串

  • 此步骤从库会中断。若业务有使用从库,可以先修改连接串至主库,避免中断

将原从库连接串重命名加 -old

将新从库连接串重命名为旧从库连接串,避免从库业务需重新配置

十三、 断开升级前后主从同步链路

从库关系重置
CALL mysql.rds_stop_replication;
CALL mysql.rds_reset_external_master;

十四、回收旧实例

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2094175.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【荒原之梦考研数学】考研没有人支持,怎么办?

一部分考研的同学可能会发现,当我们上小学、初中和高中的时候,无论家里人还是亲戚朋友,都会非常支持我们的学习。 但到了考研的时候,我们获得的支持可能就会变得稍微小一些,因为这个时候,家里人可能想着&a…

Java 集合之List

一、集合常用API 1.添加相关的方法 add(E e) 确保此collection包含指定的元素&#xff08;可选操作&#xff09; addAll(Collection<? extends E> c) 将指定集合中的元素都添加到此集合中&#xff08;可选操作&#xff09; 2.删除相关的方法 clear() 移除这个…

MongoDB之MongoDB Compass工具

MongoDB Compass 是 MongoDB 官方提供的一款图形化用户界面 (GUI) 工具&#xff0c;用于与 MongoDB 数据库进行交互和管理。Compass 提供了丰富的功能&#xff0c;能够帮助开发者、数据库管理员以及数据分析师轻松管理和分析 MongoDB 数据。以下是对 MongoDB Compass 的详细介绍…

英特尔Arrow Lake和Lunar Lake不受Vmin Shift不稳定性影响

近日&#xff0c;英特尔在其官方博客中发布了一篇关于Vmin Shift不稳定性问题的文章&#xff0c;该问题已知影响到了第13代&#xff08;Raptor Lake&#xff09;和第14代&#xff08;Raptor Lake Refresh&#xff09;酷睿处理器。根据英特尔的确认&#xff0c;其下一代Core Ult…

最长公共子序列补充题型:判断是否是子字符串

&#x1f9ca;&#x1f9ca;&#x1f9ca;新题型 最长公共子序列是基于动态规划思想&#xff0c;判断子序列长度的&#xff0c;这种方法的弊端就是dp需要很大&#xff0c;如果字符串长度很长就会超出内存限制。这里我们补充一种字符串很长的题型&#xff1a;给出字符串s和字符…

【 html+css 绚丽Loading 】 000029 三元化虚阵

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享htmlcss 绚丽Loading&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495…

VMware15安装教程(Pro版)

[VMware Workstation Pro 15.5下载链接]: https://ga90eobypbb.feishu.cn/docx/Jg2AdvMukowUVyxaCI8co2RfnGh 1.选中下载的压缩包&#xff0c;鼠标右键解压到”VMware Workstation Pro 15.5“文件夹 2.双击打开解压出来的文件夹&#xff0c;选中“VMware-workstation-full-15…

LVGL 控件之矩阵按钮(lv_buttonmatrix)

目录 一、矩阵按键1、组成2、创建矩阵3、按钮宽度4、按键属性5、按钮互斥6、按钮文本重着色7、按钮矩阵部件的事件8、API 函数二、例程 一、矩阵按键 1、组成 按钮矩阵部件由两个部分组成&#xff1a;主体背景和按钮&#xff0c;示意图如下&#xff1a; LV_PART_MAIN&#xf…

DiskCache:Python开发者的磁盘缓存利器

什么是DiskCache&#xff1f; DiskCache是一个用纯Python编写的轻量级缓存库&#xff0c;它利用磁盘空间来存储缓存数据。与传统的内存缓存相比&#xff0c;DiskCache可以利用磁盘上未被充分利用的空间&#xff0c;为需要大量缓存数据的应用程序提供支持。它的核心是基于SQLite…

C++创建并初始化对象

文章目录 一、对象的创建1.1 定义类1.2 创建对象 二、对象的初始化2.1 默认构造函数2.2 带参数的构造函数2.3 初始化列表 三、拷贝构造函数四、对象的销毁五、总结 视频讲解笔记在栈上创建在堆上创建new 在C中&#xff0c;创建并初始化对象是面向对象编程&#xff08;OOP&#…

基于yolov8的驾驶员行为检测疲劳检测系统python源码+onnx模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv8的驾驶员行为检测疲劳检测系统是一种创新的驾驶安全解决方案。该系统利用YOLOv8这一先进的目标检测算法&#xff0c;结合驾驶员疲劳驾驶数据集&#xff0c;能够实时、准确地监测并分析驾驶员的面部表情和行为模式&#xff0c;从而快速识别疲劳状态。 …

关于分布式数据库缓存设计的那点事和实践

目录 案例 【题目】 【问题 1】(9 分) 【问题 2】(8 分) 【问题 3】(8 分) 【答案】 【问题 1】答案 【问题 2】解析 【问题 3】解析 相关推荐 案例 阅读以下关于分布式数据库缓存设计的叙述&#xff0c;在答题纸上回答问题 1 至问题 3。 【题目】 某企业是为城市高…

【网络协议】精讲OSI七层模型、TCP/IP四层、五层模型区别!图解超赞超详细!!!

目录 1. OSI与TCP/IP模型的网络协议层次结构差异 1.1 OSI模型的七层结构 1.2 TCP/IP模型的四层结构 1.3 TCP/IP模型的五层结构 2. OSI七层模型和TCP/IP协议模型的区别 2.1 区别总结&#xff1a; 3. 网络协议分层的优点 1. OSI与TCP/IP模型的网络协议层次结构差异 协议分…

拥抱开源拥护国产|暴雨打造最强AI的服务器操作系统!

8月30日&#xff0c;主题为“进化重构赴未来”的2024龙蜥操作系统大会(OpenAnolis Conference)在北京举办。龙蜥社区作为国内领先的开源操作系统根社区&#xff0c;推出的Anolis OS及衍生版装机量已突破800万套&#xff0c;实现了从开源到商业化的良性循环发展。 2024 龙蜥操作…

【惊天BUG】select * from 表 where value = 0;查询结果让大师兄都傻眼了

前言 &#x1f34a;缘由 线上问题把我坑&#xff0c;一查数据让我蒙 &#x1f423;闪亮主角 大家好&#xff0c;我是JavaDog程序狗 今天跟大家分享一个本狗造成的线上事故&#xff0c; 一个简单的SQL查询语句导致的bug &#x1f608;你想听的故事 最近狗哥有点飘&#xf…

MCU1.51单片机介绍

1.单片机&#xff08;MCU 全称 Mirco Controller Unit 意为微小控制器的集合&#xff09; 相当于一台迷你电脑&#xff08;集成了很多硬件&#xff09; 2.作用 传感&#xff08;采集信息&#xff09;&#xff0c;处理&#xff08;CPU Central Processing Unit 中央处理器&am…

智能的瓶颈在于事物表征的弥散与聚合性(弥聚性)

动态“弥散与聚合性”&#xff08;弥聚性&#xff09;是智能系统面临的一个重要挑战。这个概念涉及如何在处理信息时平衡广度和深度&#xff0c;以及如何有效地表征和组织知识。 &#xff08;1&#xff09;弥散性 弥散性指的是信息或知识的分散性和多样性。智能系统需要处理来自…

非对称RAID破解SSD异构存储难题

上一篇文章&#xff08;Kioxia的NVMe RAID卸载有何亮点&#xff1f;&#xff09;介绍了NVMe RAID卸载方案内容。本文我们结合一篇学术论文&#xff0c;学习一下新的非对称RAID架构&#xff5e; 随着大数据时代的到来&#xff0c;全闪存阵列&#xff08;All-Flash Arrays, AFAs&…

校园一卡通|基于SprinBoot+vue的校园一卡通系统(源码+数据库+文档)

校园一卡通系统 基于SprinBootvue的校园一卡通系统 一、前言 二、系统设计 三、系统功能设计 系统功能实现 后台模块实现 管理员功能实现 学生功能实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍…

linux驱动 -- PWM配置和SysFs操作方法

1&#xff1a;PWM介绍 PWM的定义为:可调节脉冲调节器&#xff0c;换句话来说就是一个总周期不变&#xff0c;占空比可调节的方波。 2&#xff1a;PWM的总周期和占空比、有效点平 方波&#xff1a;在信号领域一般分为数字信号和模拟信号&#xff0c;数字信号就两种状态&#…