docker mysql更新升级版本

一、环境说明

操作系统:Centos7

数据库版本: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

相关推荐
Jewel Q几秒前
QEMU、KVM、Docker、K8s(Kubernetes)
docker·容器·kubernetes
李慕婉学姐20 分钟前
【开题答辩过程】以《基于PHP的动漫社区的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
开发语言·mysql·php
学Linux的语莫32 分钟前
prometheus、grafana的docker搭建
docker·容器·prometheus
lisanmengmeng33 分钟前
zentao的prod环境升级(一)
linux·运维·数据库·docker·容器·禅道
それども39 分钟前
insertOnDuplicateKey 和 upsert 区别
数据库·mysql
kkoral1 小时前
单机docker部署的redis sentinel,使用python调用redis,报错
redis·python·docker·sentinel
大学生资源网1 小时前
基于springboot的万亩助农网站的设计与实现源代码(源码+文档)
java·spring boot·后端·mysql·毕业设计·源码
q_19132846951 小时前
基于SpringBoot2+Vue2的诗词文化传播平台
vue.js·spring boot·mysql·程序员·计算机毕业设计
为什么不问问神奇的海螺呢丶2 小时前
服务器巡检报告-基于categraf 采集数据-存入Prometheus-写入mysql后生成报告
服务器·mysql·prometheus
秋氘渔3 小时前
智演沙盘 —— 基于大模型的智能面试评估系统
python·mysql·django·drf