欢迎您光临本站,如有问题请及时联系我们。

记录一次MySQL升级的运维实践

  MySQL升级的实质:

  对数据字典的升级

  数据字典有:mysql、information_schema、performance_schema、sysschema。

  MySQL升级的两种方式:

  in-placeupgrade:

  适合小版本的升级。

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

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

  logicalupgrade:

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

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

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

  升级前的准备:

  提前做好备份。

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

  在官方网站的generalinformation—>whatisnewinmysql5.7

  升级的注意事项:

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

  注意SQLmode的变化

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

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

  程序层是否都正常

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

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

  存储引擎的变化

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

  注意字符集的乱码问题

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


  In-placeupgrade升级MySQL

  环境:

  5.6.15—>5.7.20


  升级前的准备:

  备份+留意新版本的变更内容

  升级操作:

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


  #tar-xzvfmysql-5.7.20-linux-glibc2.12-x86_64.tar.gz#ln-smysql-5.7.20-linux-glibc2.12-x86_64mysql5.7


  2、关闭当前MySQL(5.6)


  #mysql-uroot-p-S/data/mysql3308/mysql3308.sock–execute=”SETGLOBALinnodb_fast_shutdown=0″#mysqladmin-uroot-p-S/data/mysql3308/mysql3308.sockshutdown


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


  #cd/usr/local#mvmysqlmysql5.6#mvmysql5.7mysql


  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做升级,若升级失败了怎么办?

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


来源:本文由E8运维原创撰写,欢迎分享本文,转载请保留出处和链接!