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

相关推荐
阿杰 AJie2 小时前
MySQL 聚合函数
android·数据库·mysql
JavaGuide3 小时前
IntelliJ IDEA 2026.1 EAP 发布!拥抱 Java 26,Spring Boot 4 深度支持!
java·后端·mysql·springboot·idea·大厂面试·javaguide
达梦产品与服务3 小时前
SQLark 实战 | 如何快速导入数据至达梦、Oracle、MySQL、PG 数据库
mysql·oracle·达梦数据库·数据导入·pg数据库
weixin_462446233 小时前
使用 Python 脚本自动化管理 Docker 容器:启动、修改密码、删除及系统资源监控
python·docker·自动化·系统监控
liux35283 小时前
MySQL集群架构:MySQL InnoDB Cluster (MIC)详解(十一)
数据库·mysql·架构
溜达的大象3 小时前
Navidrome 打造专属无损音乐库,加载cpolar局域网外访问也能超丝滑
阿里云·docker·云原生·eureka
小北方城市网3 小时前
MySQL 索引优化实战:从慢查询到高性能
数据库·spring boot·后端·mysql·rabbitmq·mybatis·java-rabbitmq
l1t3 小时前
DeepSeek对AliSQL 集成 DuckDB 的总结
数据库·sql·mysql·duckdb
SeaTunnel4 小时前
Apache SeaTunnel MySQL CDC 支持按时间启动吗?
大数据·数据库·mysql·开源·apache·seatunnel
Wpa.wk5 小时前
Docker容器 - 了解Docker基础命令(容器+镜像命令)
运维·经验分享·测试工具·docker·容器