0

0

如何在mysql中升级高可用集群

P粉602998670

P粉602998670

发布时间:2025-10-27 14:51:02

|

434人浏览过

|

来源于php中文网

原创

先确认版本兼容性、应用依赖及备份完整性,再按架构选择升级路径。对Group Replication或InnoDB Cluster采用滚动升级,先升从节点最后升主节点;MHA/Orchestrator架构先升备库再切换主库;PXC需停集群全量升级。替换二进制后启动实例并运行mysql_upgrade,验证节点状态与复制正常。升级后检查集群可用性、性能指标及监控告警,更新文档,特别注意sql_mode和caching_sha2_password认证插件带来的连接风险。

如何在mysql中升级高可用集群

在 MySQL 中升级高可用集群是一项需要谨慎操作的任务,因为涉及多个节点、数据一致性以及服务连续性。常见的 MySQL 高可用架构包括基于 MySQL Group ReplicationInnoDB Cluster(通过 MySQL Shell 管理)、Percona XtraDB Cluster (PXC) 或使用中间件如 ProxySQL + MHA/Orchestrator 的主从复制方案。以下是通用的升级流程和关键注意事项。

评估当前环境与目标版本兼容性

在开始升级前,必须确认以下几点:

  • 当前 MySQL 版本与目标版本之间的兼容性:查看官方文档中关于版本间的变更日志,特别是系统表结构、参数废弃、字符集默认值等变化。
  • 存储引擎支持情况:确保使用的 InnoDB、MyISAM 等引擎在新版本中仍被支持且行为一致。
  • 应用兼容性:检查应用程序是否依赖某些已被弃用的语法或功能。
  • 备份现有集群状态:对所有节点进行完整物理或逻辑备份(建议使用 Percona XtraBackup 或 mysqldump),并验证可恢复性。

选择合适的升级路径

根据部署方式不同,升级策略也有所区别

场景一:基于 MySQL Group Replication / InnoDB Cluster

  • 支持滚动升级(Rolling Upgrade),即逐个节点停机升级,不影响整体集群可用性。
  • 使用 MySQL Shell 可以自动检测集群状态并引导升级过程:
    dba.upgradeToInnoDBCluster()cluster.setupRouter() 等命令配合版本迁移。
  • 先升级种子成员以外的节点,最后升级担任 primary 角色的节点(对于单主模式)。

场景二:主从复制 + MHA/Orchestrator 架构

名品购物网店系统
名品购物网店系统

适合品牌专卖店专用,从前台的美工设计就开始强调视觉形象,有助于提升商品的档次,打造网店品牌!后台及程序核心比较简洁,着重在线购物,去掉了繁琐的代码及垃圾程式,在结构上更适合一些中高档的时尚品牌商品展示. 率先引入语言包机制,可在1小时内制作出任何语言版本,程序所有应用文字皆引自LANG目录下的语言包文件,独特的套图更换功能,三级物品分类,购物车帖心设计,在国内率先将购物车与商品显示页面完美结合,完

下载
  • 先升级备库(Slave/Replica),再切换主库(Master),实现无缝过渡。
  • 升级过程中暂停复制线程,更新软件后重启实例,并重新启用复制。
  • MHA 需要手动控制 failover 流程;Orchestrator 支持更灵活的在线切换。

场景三:Percona XtraDB Cluster (PXC)

  • PXC 不支持跨大版本的在线升级(如 5.7 → 8.0 必须停集群)。
  • 推荐采用“关闭整个集群 → 升级所有节点 → 按顺序启动”的方式。
  • 注意 wsrep_provider 版本与 MySQL 主版本匹配。

执行升级操作的关键步骤

无论哪种架构,基本流程如下:

  • 停止 MySQL 服务:在待升级节点上安全关闭 mysqld 进程。
  • 替换二进制文件或 RPM/DEB 包
    • 使用 yum/dnf/apt 安装新版包,或手动替换 mysql-server 二进制。
    • 确保配置文件(my.cnf)中的参数与新版本兼容(例如 sql_mode、default_authentication_plugin)。
  • 启动 MySQL 并运行 mysql_upgrade
    • MySQL 8.0 起 mysql_upgrade 已整合进 mysqld 启动流程,但仍需留意输出日志。
    • 该步骤会检查系统表、修复权限、更新字典数据等。
  • 验证节点加入集群状态
    • 查看 error log 是否有异常。
    • 执行 SHOW DATABASES;SELECT * FROM performance_schema.replication_group_members; 确认正常加入。

升级后的验证与监控

完成所有节点升级后,务必进行以下检查:

  • 确认集群各节点处于 ONLINE 状态,无延迟或报错。
  • 测试读写流量是否正常,尤其是事务提交、DDL 执行性能。
  • 检查慢查询日志、连接数、锁等待等指标是否有异常波动。
  • 更新监控系统(如 Prometheus + Grafana、Zabbix)中关于 MySQL 版本的告警规则。
  • 更新文档,记录升级时间、版本信息、回滚方案等。

基本上就这些。关键是做好备份、按顺序操作、密切观察日志。虽然流程看似复杂,但只要规划得当,MySQL 高可用集群的升级是可以平稳完成的。不复杂但容易忽略的是参数兼容性和认证插件的变化,比如 native password 到 caching_sha2_password 的切换可能导致客户端连接失败,记得提前处理。

相关专题

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

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

663

2023.06.20

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

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

246

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中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

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

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

253

2023.07.25

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

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

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

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

529

2023.08.11

mysql忘记密码
mysql忘记密码

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

599

2023.08.14

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

3

2026.01.19

热门下载

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

精品课程

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

共48课时 | 1.8万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 801人学习

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

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