如何升级mysql5.6到5.7 for windows

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何升级mysql5.6到5.7 for windows相关的知识,希望对你有一定的参考价值。

1. 下载 5.7.30 的 zip 包并解压到新的目录。
2. 安装 Visual C++ 2012/2013(或更多版本)。
3. 停应用,停止 5.6 实例(可以通过停服务来操作,停止服务前建议记录一下 GTID 或 binlog file 和 position 位置),删除服务。
4. 备份一份 5.6 实例的 datadir,包括 binlog(整个目录 copy 到别的目录存放)。
5. 拷贝 5.6 实例的 datadir 和 my.ini 到 5.7 实例 basedir 目录,调整并优化参数值(注意要确保路径一致,确认已开启 5.7 新特性相关参数,如增强半同步、MTS 等)。
6. 修改系统环境变量,把可执行路径指向 5.7 实例的 basedir/bin。
7. 启动 5.7 实例,创建服务并启动。
8. 验证服务端、客户端版本是否正确。
9. 确认无误后,执行 mysql_upgrade 升级数据字典(会升级系统库:mysql,ps,sys,没有会重建)。
10. 重启实例。
11. 再次校验 5.7 的参数,尽量保持与 5.6 的兼容,尤其要注意 sql_mode 的默认值对业务的影响。
12. 清理 5.6 实例的 basedir 和 datadir 目录(可选)。
13. 如果是主从环境,还要考虑 slave_net_timeout 参数默认值改变带来的影响(主库 error 日志中出现 “ER_RPL_ZOMBIE_ENCOUNTERED” 的报错)。
在 5.7.7 以前,该参数默认是 3600s,之后改为了 60s,需要重新执行 change master to 语句,并且显式指定 master_heartbeat_period=xx,因为从 5.7.4 开始,只有执行 reset slave 才能将其重置为默认值(slave_net_timeout 值的一半)。另外提一句,也是从 5.7.4 开始,执行 change master to 语句时,可以不用先停止复制线程了。
参考技术A MySQL各产品线更新.5.6.15/5.5.35 开发版5.7.3 2013-12-03 之前版本2013-09-20的5.6.14/5.5.34,主要是Bug修正。5.1还是5.1.72. 主要是Performance Schema增强,Cmake时增加了WITH_ASAN 以及一些Bug修正。

以上是关于如何升级mysql5.6到5.7 for windows的主要内容,如果未能解决你的问题,请参考以下文章

Windows下mysql5.6升级到5.7的方法

MySQL5.6到5.7版本升级采用IN-PLACE的升级方式需要具体关注的地方

MySQL5.6升级5.7步骤

mysql5.6升级5.7

将 MySQL 5.6 升级到 5.7

升级过程中从 5.6 到 5.7 的 AWS RDS MySQL 复制