docker mysql更新升级版本

一、环境说明

操作系统:Centos7
部署方式:Docker version 20.10.14

数据库版本:MySql 8.0.22 数据库中数据量不大,处于开发/测试环境,风险较低

二、升级原因

升级是因为测评漏洞,在进行国家三级等级保护测评过程中,漏扫发现多个MySql漏洞。
在这里插入图片描述

三、升级方法及步骤

下面来介绍一下具体的操作:

官方升级文档参考:

https://dev.mysql.com/doc/refman/8.0/en/windows-upgrading.html#windows-upgrading-zip-distribution

例如我原先部署的是mysql 8.0.22版本

之前老版本运行的mysql必须是将数据挂载出来的,否则不能按照我下面的步骤操作,你得把mysql中的数据复制到宿主机上来才能这么操作

1.需要提前告知用户,升级数据库操作会短暂停止服务,确保他们了解到可能的中断。
//老的数据库启动命令
docker run --restart=always --name mysqlori -v /nets/mysql/conf:/etc/mysql/conf.d  -v /nets/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -p 3306:3306 mysql:8.0.22

如果不记得之前的命令了,主要是-v和-e设置的参数

docker inspect -f '{{ .Mounts }}' mysqlori
得到如下-v信息,自己转成-v参数即可
[{bind  /nets/mysql/conf /etc/mysql/conf.d   true rprivate} {bind  /nets/mysql/data /var/lib/mysql   true rprivate}]

docker inspect --format='{{json .Config.Env}}' mysql8035
得到如下-e信息,像下面的很好判断,例如MYSQL_ROOT_PASSWORD是我自己指定的,而其他不是
["MYSQL_ROOT_PASSWORD=123456","PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.16","MYSQL_MAJOR=8.0","MYSQL_VERSION=8.0.35-1.el8","MYSQL_SHELL_VERSION=8.0.35-1.el8"]

那么最终还原出来的命令就是
docker run --restart=always --name mysqlori -v /nets/mysql/conf:/etc/mysql/conf.d  -v /nets/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -p 3306:3306 mysql:8.0.22
也即如下格式
docker run --restart=always --name {names} -v /nets/mysql/conf:/etc/mysql/conf.d  -v /nets/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -p {ports} {IMAGE}

#拉取最新的mysql镜像,最好是写明版本,例如
docker pull mysql:8.0.35

2.备份数据库
通过mysqldump或者其他方式都行,但记得一定要备份数据库。虽然说之前如果把数据外挂出来,启动新版本一般是不会丢失数据的,但以防万一还是备份一下比较合理。

3.停止现有的mysql服务
docker stop mysqlori

4.移除原有的mysql服务
docker rm mysqlori

5.启动新的mysql服务(这里的目录映射记得一定要跟之前老版本时候的保持一致,因为新版本的数据库启动后会自动加载老版本数据目录下的数据,如果你映射了一个新的目录那原来的数据你大概率只能手动恢复进新数据库了)
docker run --restart=always --name mysql8035 -v /nets/mysql/conf:/etc/mysql/conf.d  -v /nets/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d -p 3306:3306 mysql:8.0.35

四、windows上的mysql升级方法及步骤

具体请参考以下的官方文档链接
https://mysql.net.cn/doc/refman/8.0/en/windows-upgrading.html

这里我也找到另一个博主写的博文可以供大家参考
https://www.cnblogs.com/Jingkunliu/p/14242787.html

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

iRayCheung

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值