MySQL 小版本升级

文若3年前技术文章2622


MySQL 版本一般不需要经常升级,如果需要使用某个新特性或者修改 BUG 就不得不升级小版本。

1. 环境调研

  1. 当前数据库版本和需要升级到某个版本,如果升级需求 5.6.22+ 那么我们直接下载 5.6 最新 GA 版本即可;

  2. 了解环境的复制拓扑,根据复制架构可以有不同的方案选择,如果是主从 + keepalived 架构,我们可以先升级从库,再将 VIP 切换到从库,对业务影响最小(短暂中断)然后再去升级主库即可。如果业务可以停机或者是单节点可以忽略。

2. 操作升级

升级方式有两种一种是使用 mysql_upgrade 直接升级数据字典库,这种方法不能跨大版本升级,另外一种就是使用 mysqldump 导出数据,再导入到新实例即可。

当前环境是 MySQL 主从复制 + keepalived 选择的升级方式是 mysql_upgrade 方式,当前版本是 5.7.32 计划升级为 5.7.33 。

172.16.104.55

Master

5.7.32

172.16.104.57

Slave

5.7.32

官方存档下载地址:MySQL 存档版本下载

carbon.png


2.1 将升级的二进制安装包上传到服务器

[root@db01 opt]# ls
mysql-5.7.33-linux-glibc2.12-x86_64.tar.gz

2.2 保障主从数据一致

我们首先升级从库,升级前需要确认从库数据已追上主库(必要时可以先停止主库写入)然后 stop slave 停止复制;

root@mysql 14:02:  [(none)]>stop slave;
Query OK, 0 rows affected (0.00 sec)

2.3 查看 sql_mode 并记下它的值:

select @@sql_mode;

2.4 配置 MySQL 通过设置 innodb_fast_shutdown 执行慢速关闭:

root@mysql 17:08:  [(none)]> select @@innodb_fast_shutdown;
+------------------------+
| @@innodb_fast_shutdown |
+------------------------+
|                      1 |
+------------------------+
1 row in set (0.01 sec)	

root@mysql 17:08:  [(none)]> SET GLOBAL innodb_fast_shutdown=0;
Query OK, 0 rows affected (0.00 sec)

2.5 停止 MySQL 服务

mysqladmin -u root -p shutdown

2.6 备份数据目录

当升级发生意外时,可以快速回滚,如果空间充裕可以直接备份整个 mysql 数据目录

-- 备份整个数据目录
cp -ar data/ data.bak

2.7 解压现有的 mysql 二进制包,替换 basedir

如果安装路径没有使用软链接的方式,那么这一步直接 mv 安装路径,然后将二进制包解压到原来的安装路径。

carbon-1.png

unlink mysql
-- 解压新的安装包
tar -zxvf mysql-5.7.33-linux-glibc2.12-x86_64.tar.gz

此时新的安装目录为:/home/mysql-5.7.33-linux-glibc2.12-x86_64

ln -s /home/mysql-5.7.33-linux-glibc2.12-x86_64 /usr/local/mysql

2.8 启动并升级 MySQL

./mysqld_safe --defaults-file=/etc/my.cnf --datadir=/data/mysql57/data/ --user=mysql &
mysql_upgrade -uroot -p

注意:mysql_upgrade 需要使用管理员账号,否则会出现拒绝访问等问题

2.9 重启 MySQL 测试是否正常

  1. 重启 MySQL 服务

  2. 检查能否正常访问

carbon.png

再次查询 sql_mode 对比是否与升级前一致,如果不一致核对是否与业务有关,决定是否需要调整。

select @@sql_mode;

到此为止备库就升级完成了,将 VIP 切换到备库,然后重复 2.1 ~ 2.9 步骤即可。


相关文章

8.0 新特性-Generated Invisible Primary Key

8.0 新特性-Generated Invisible Primary Key

说明MySQL Innodb 引擎采用的是 IOT(索引组织表)存储方式,主键的重要性就不言而喻。在早期版本用户如果没有显式指定主键,会自动生成隐藏主键 row_id 来组织 B+ 树,隐藏主键 ro...

oracle 回退db补丁31718723报错ins_emagent.mk:113: warning: overriding recipe for target `nmosudo'

报错内容如下:ins_emagent.mk:113: warning: overriding recipe for target `nmosudo'原因:该补丁的readme有说明该报错如下图参考mo...

理解YAML文件

YAML 基础它的基本语法规则如下:大小写敏感使用缩进表示层级关系缩进时不允许使用Tab键,只允许使用空格。缩进的空格数目不重要,只要相同层级的元素左侧对齐即可# 表示注释,从这个字符一直到行尾,都会...

linux中的buffer和cache

linux中的buffer和cache

linux中的buffer和cache一、buffer和cache的来源及应用1、来源Buffer 是缓冲区,而 Cache 是缓存,两者都是数据在内存中的临时存储。那么,这两种“临时存储”有什么区别...

oracle手工管理的不完全恢复

一)使用当前控制文件做不完全恢复示例1: 恢复过去某个时间点误删除的table(基于时间点的不完全恢复)前提:在这个状态下先在OS下做一个数据文件和控制文件的冷备。SQL> shutdown i...

ACK版本升级

ACK版本升级

需求:将ACK版本从1.14.8升级至1.16.9升级前注意事项:集群升级需要机器可以公网访问,以便下载升级所需的软件包。集群升级Kubernetes过程中,可能会有升级失败的情况,为了您的数据安全,...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。