MySQL5.7新增了不少新功能,比如:Online DDL、多源复制、增强半同步、表空间传输、sys 库、Group Replication等。
一、MySQL升级的两种方式
1、in-place upgrade:
适合小版本的升级。
即 关闭当前的MySQL,替换当前的二进制文件或包,在现有的数据目录上重启MySQL,并运行mysql_upgrade.
特点:不改变数据文件,升级速度快;但,不可以跨操作系统,不可以跨大版本(5.5—>5.7)
2、logical upgrade:
适合不同操作系统的MySQL升级,大版本之间的升级。
即:使用mysqldump 或 mydumper 导入导出数据,实现版本的升级。
特点:可以跨操作系统,跨大版本;但,升级速度慢,容易出现乱码等问题。
二、MySQL升级的实质
对数据字典的升级
数据字典有:mysql、information_schema、performance_schema、sys schema。
三、升级前的准备
提前做好备份。
了解新版本变更的信息(哪些不再兼容,不再支持哪些功能)
四、升级过程
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
备注:
在做升级时,一般创建一个从库进行升级,若升级失败,也不会影响到主库;若升级成功,测试也成功,便会将其他的从库也逐渐升级到新版本,最后将主库下线,提升一个从库做新主库,对旧主库进行版本升级。