MySQL如何升级

27次阅读
没有评论

共计 1989 个字符,预计需要花费 5 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家分享的是有关 MySQL 如何升级的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。

MySQL5.7 新增了不少新功能,比如:Online DDL、多源复制、增强半同步、表空间传输、sys 库、Group Replication 等。最近终于等到了一个机会,将 MySQL 升级到 5.7,很是兴奋不已。

MySQL 升级的概述

MySQL 升级的实质:

对数据字典的升级

数据字典有:mysql、information_schema、performance_schema、sys schema。

MySQL 升级的两种方式:

in-place upgrade:

适合小版本的升级。

即 关闭当前的 MySQL,替换当前的二进制文件或包,在现有的数据目录上重启 MySQL,并运行 mysql_upgrade.

特点:不改变数据文件,升级速度快;但,不可以跨操作系统,不可以跨大版本(5.5— 5.7).

logical upgrade:

适合不同操作系统的 MySQL 升级,大版本之间的升级。

即:使用 mysqldump 或 mydumper 导入导出数据,实现版本的升级。

特点:可以跨操作系统,跨大版本;但,升级速度慢,容易出现乱码等问题。

升级前的准备:

提前做好备份。

了解新版本变更的信息(哪些不再兼容,不再支持哪些功能)

在官方网站的 general information— what is new in mysql 5.7

升级的注意事项:

确认新版本是否有重大变更

注意 SQL mode 的变化

比如:在 MySQL5.7 中发生了 SQL mode 的变化,对不再支持的 SQL mode,部分 SQL 会跑不通,此时可以清空 SQL mode,跑完之后在设置 SQL mode。

升级成功后,确认业务 SQL 是否可以跑通

程序层是否都正常

有时原使用的程序语言部分内容不被支持新版本数据库。比如,有一次在 5.1 时用的是 PHP4.0,但升级到 5.6,PHP 的某些函数不被支持。

在升级完成之后,一定要在测试时使用和线上版本相同的程序,测试是否存在问题。

存储引擎的变化

比如:在未来的 5.8 版本,不再支持 myisam 引擎。

注意字符集的乱码问题

接下来是,使用 in-place upgrade 方式,将 MySQL5.6 升级到 MySQL5.7。

In-place upgrade 升级 MySQL

环境:

5.6.15 — 5.7.20

升级前的准备:

备份 + 留意新版本的变更内容
升级操作:

1、对 5.7 的软件包,下载,解压

# tar -xzvf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz
# ln -s mysql-5.7.20-linux-glibc2.12-x86_64 mysql5.7

2、关闭当前 MySQL(5.6)

# mysql -u root -p -S /data/mysql3308/mysql3308.sock --execute= SET GLOBAL innodb_fast_shutdown=0 
# mysqladmin -u root -p -S /data/mysql3308/mysql3308.sock shutdown

3、替换二进制文件(5.7 替换 5.6)

# cd /usr/local
# mv mysql mysql5.6
# mv mysql5.7 mysql

4、使用现有的数据目录启动 MySQL

# mysqld_safe --user=mysql --socket=/data/mysql3308/mysql3308.sock -p --skip-grant-tables --datadir=/data/mysql3308/data

5、检查所有表是否与当前版本兼容,并更新系统库

# mysql_upgrade -uroot -p -S /data/mysql3308/mysql3308.sock
注:mysql_upgrade 的作用是检查所有库的所有表是否与当前的新版本兼容,并更新系统库。

6、重启,确保对系统表所做的变更得以生效

# mysqld --defaults-file=/data/mysql3308/my3308.cnf  
# mysql -uroot -p -S /data/mysql3308/mysql3308.sock

至此,升级完成。

问题:对 MySQL 做升级,若升级失败了怎么办?

在做升级时,一般创建一个从库进行升级,若升级失败,也不会影响到主库;若升级成功,测试也成功,便会将其他的从库也逐渐升级到新版本,最后将主库下线,提升一个从库做新主库,对旧主库进行版本升级。

感谢各位的阅读!关于“MySQL 如何升级”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1989字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)