社区投稿 | MySQL 8.0.16 告别mysql_upgrade升级方式

原文链接: https://my.oschina.net/actiontechoss/blog/3070140

原创: 田帅萌


作者简介

田帅萌,京东数科DBA,爱可生开源社区志愿者。

最熟悉的命令要消失了!

MySQL 8.0.16 开始,MySQL 不推荐使用mysql_upgrade。取而代之的是

server upgrade的升级方式。

 

一、为什么变更升级方式

官方为什么这么做?

1. 升级速度更快

2. 升级更简单

3. 安全性更好

4. 减少升级步骤,方便自动化

5. 不需要重启 MySQL 6. 即插即用

 

二、新旧方式升级流程对比

在 MySQL 8.0.16 之前:

社区投稿 | MySQL 8.0.16 告别mysql_upgrade升级方式_第1张图片

1. 关闭 MySQL,替换新的二进制 MySQL

2. 启动 MySQL,让服务器升级 DD(数据字典)表

3. 运行 mysql_upgrade,更新系统表和用户表

4. 加载新的帮助表

5. 重启 MySQL

从 MySQL 8.0.16 开始:

社区投稿 | MySQL 8.0.16 告别mysql_upgrade升级方式_第2张图片

1. 关闭 MySQL,替换新的二进制 MySQL

2. 启动 MySQL,升级 DD(数据字典)表和系统表、用户表和帮助表

升级的时间和操作都会大幅度缩短,操作步骤也减少了很多,更方便了用户。

 

三、关于 MySQL 8.0.16 的新的升级方式

看看该如何使用新的升级姿势?

在 mysqld 额外添加了一个新的选项 --upgrade。可选值为 NONE,AUTO,MINIMAL,FORCE。

姿势是这样的:

/usr/local/mysql/bin/mysqld --upgrade=NONE

新的选项都代表什么?

**NONE:**不尝试进行升级

**AUTO:**默认选项,MySQL 进行数据字典升级和服务升级

**MINIMAL:**仅升级数据字典

**FORCE:**强制升级,类似旧的 mysql_upgrade –force

 

MySQL 8.0.16 新的升级方式,总体来说分为2个步骤。

1. 升级数据字典(DD)

2. 服务器升级:升级 MySQL 系统表、升级用户表、升级 sys 表、升级帮助更新表

可能出现的问题:

1. 升级数据字典:原子性操作。如果操作失败,则根据目录可以回滚回来。

2.升级系统表、用户表:可以从备份还原中恢复。

个人建议,针对升级:

1. 使用新的版本,尤其是 MySQL 8.0 系列。每个版本都有新特性,还有bug的修复,定期小版本升级会使你的 MySQL 更加稳定。

2. 阅读新版本的Release。 3.最后,升级之前要做好备份,以便升级失败回滚使用。

转载于:https://my.oschina.net/actiontechoss/blog/3070140

你可能感兴趣的:(社区投稿 | MySQL 8.0.16 告别mysql_upgrade升级方式)