0

0

如何在mysql中升级复制环境版本

P粉602998670

P粉602998670

发布时间:2025-10-15 11:30:01

|

834人浏览过

|

来源于php中文网

原创

先升级从库再升级主库,确保复制兼容性。1. 升级前备份数据库、检查版本兼容性、停非必要连接、设binlog为ROW模式、记录复制位点。2. 从库升级:停复制和MySQL服务,安装新版本并启动,运行mysql_upgrade(如需),重启复制线程并验证状态。3. 主库升级可选主从切换或直接升级:前者将已升级从库提为主库,原主库降级为从库重新加入;后者在从库追平后停主库,升级并启动,恢复写入。4. 升级后验证复制状态、数据一致性,监控应用行为与日志。按步骤操作并参考官方文档可确保平稳升级。

如何在mysql中升级复制环境版本

在 MySQL 中升级复制环境版本,需要确保主库和从库的兼容性,并按正确顺序操作,避免数据中断或复制失败。核心原则是:先升级从库,再升级主库,并且建议逐个实例进行,降低风险。

1. 升级前准备

确保整个升级过程安全可靠,必须做好以下准备工作:

    • 备份所有数据库:包括主库和所有从库,使用 mysqldump 或物理备份工具(如 Percona XtraBackup)。
    • 检查 MySQL 版本兼容性:确认新旧版本之间支持复制,参考官方文档中的“升级路径”说明,例如 5.7 → 8.0 需注意系统表结构变化。
    • 停止非必要应用连接:减少升级期间的写入压力。
    • 确保 binlog 格式为 ROW 或 MIXED:特别是升级到 8.0 时,推荐使用 ROW 模式以提高兼容性和安全性。
    • 记录当前复制状态:在主库和从库上运行 SHOW MASTER STATUS;SHOW SLAVE STATUS\G,保存 File、Position、GTID(如果启用)等信息。

2. 先升级从库

从复制拓扑的末端从库开始升级,验证无误后再继续:

    • 停止从库复制线程:STOP SLAVE;
    • 关闭 MySQL 服务:systemctl stop mysql(根据实际方式停止)。
    • 安装新版本 MySQL:可通过包管理器(yum/apt)或手动替换二进制文件,注意不要覆盖数据目录。
    • 启动新版本 MySQL:systemctl start mysql,并观察错误日志是否有异常。
    • 运行 mysql_upgrade(8.0.16 之前需要):该命令更新系统表结构,修复权限表等。MySQL 8.0.16+ 已自动完成此步骤。
    • 启动复制:START SLAVE;,然后通过 SHOW SLAVE STATUS\G 检查 Slave_IO_RunningSlave_SQL_Running 是否为 Yes,且无错误。

3. 主库升级(角色切换或直接升级)

有两种常见方式处理主库升级:

稿定AI设计
稿定AI设计

AI自动去水印、背景消除、批量抠人像工具

下载
方式一:通过主从切换升级主库
    • 将已升级的从库提升为主库:确保原主库已停止写入,执行 STOP SLAVE; 并允许客户端连接。
    • 原主库作为新从库重新加入复制:升级其 MySQL 版本后,配置为新主库的从库。
    • 此方法更安全,适合不允许停机的场景。
方式二:直接升级原主库(短暂停机可接受)
    • 停止主库写入,确保所有从库已追平数据(Seconds_Behind_Master=0)。
    • 停止主库服务,升级 MySQL 软件版本。
    • 启动主库,运行 mysql_upgrade(如需),检查错误日志。
    • 确认主库正常后,恢复业务写入。

4. 验证与监控

升级完成后,必须进行全面验证:

    • 检查复制状态是否稳定:持续观察 SHOW SLAVE STATUS 中的延迟和错误信息。
    • 查询测试数据一致性:可在主从库执行相同查询,确认结果一致。
    • 监控应用行为:确保连接正常、事务处理无异常。
    • 查看 error log 和 slow log:排查潜在问题。

基本上就这些。只要按步骤来,先从库后主库,做好备份和验证,MySQL 复制环境的版本升级是可以平稳完成的。不复杂但容易忽略细节,比如 GTID 设置或系统表更新,务必参考对应版本的官方升级指南。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

665

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

247

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

256

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

531

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

600

2023.08.14

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 808人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号