MySQL的升级实战(5.7upgrade)

前言

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

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

  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
升级 MySQL 5.7.43,您可以按照以下步骤进行操作: 1. 备份数据库:在升级之前,请确保对数据库进行备份,以防止数据丢失。 2. 下载新版本:从 MySQL 官方网站(https://dev.mysql.com/downloads/mysql/)下载适用于您的操作系统的 MySQL 5.7.43 版本。 3. 安装新版本:运行下载的安装程序,并按照提示进行安装。在安装过程中,您可能需要选择安装目录和其他设置。 4. 停止现有 MySQL 服务:在升级之前,停止当前正在运行的 MySQL 服务。这可以通过在命令行中运行以下命令来实现(假设您正在使用 Windows 操作系统): ``` net stop mysql ``` 对于其他操作系统,请查阅相应的停止 MySQL 服务命令。 5. 执行升级:一旦安装完成,您可以使用 MySQL 提供的升级工具来执行升级。在命令行中导航到 MySQL 安装目录,并运行升级工具。例如,在 Windows 上,您可以执行以下命令: ``` cd C:\Program Files\MySQL\MySQL Server 5.7\bin mysql_upgrade.exe -u root -p ``` 替换路径和用户名为您的实际设置。 6. 启动新版本:升级完成后,您可以启动新版本的 MySQL 服务。这可以通过在命令行中运行以下命令来实现(假设您正在使用 Windows 操作系统): ``` net start mysql ``` 对于其他操作系统,请查阅相应的启动 MySQL 服务命令。 请注意,在执行升级之前,确保您已经阅读了 MySQL 官方文档中关于升级的详细说明,并且按照正确的步骤操作。升级 MySQL 数据库可能会有一些风险,因此务必谨慎操作并备份数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值