docker升级mysql

一、首选备份原数据库所有数据

二、在Docker中查看正在运行的MySQL容器名称,可以使用以下命令:

复制代码
docker ps --filter "name=mysql"

三、查看当前docker中正在运行mysql的版本

复制代码
docker exec -it qgz-mysql mysql -V

可以看到当前运行的版本是8.2.0

使用docker备份数据:

复制代码
docker exec your-mysql /usr/bin/mysqldump -u root --password=xxxxxx --all-databases > 20240929all_databases_backup.sql

停止原来的mysql

复制代码
docker stop xxx-mysql

拉取想要的mysql版本

复制代码
docker pull mysql:8.4.2

创建新的mysql容器:

vbscript 复制代码
docker run --name qgz-mysql842 --restart=always -p 3306:3306 -v /data/mysql/conf.d:/etc/mysql/conf.d -v /data/mysql/data2:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=yourPassword -d mysql:8.4.2

导入备份数据

复制代码
cat 20240929all_databases_backup.sql | docker exec -i qgz-mysql842 /usr/bin/mysql -u root --password=xxxxxx

启动新容器,并检查

复制代码
docker run --name qgz-mysql842 --restart=always -p 3306:3306 -v /data/mysql/conf.d:/etc/mysql/conf.d -v /data/mysql/data2:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=xxxxxxx -d mysql:8.4.2

docker logs qgz-mysql842 

查看新部署数据库版本,以确保升级成功:

复制代码
docker exec -it qgz-mysql842 mysql -V

如果用户有异常,可以

复制代码
alter user 'root'@'%' identified with caching_sha2_password by 'xxxxxxx';
相关推荐
学Linux的语莫3 小时前
k8s常用命令
linux·容器·kubernetes
火山引擎开发者社区3 小时前
Seedance 2.0上线火山方舟体验中心,API即将开放
docker·vim·emacs
freephp4 小时前
睡前讲一段docker编译镜像的故事
docker
霖霖总总4 小时前
[小技巧69]为什么总说MySQL单表“别超 2000 万行”?一篇讲透 InnoDB 存储极限
数据库·mysql
PD我是你的真爱粉7 小时前
MySQL基础-DQL语句与多表查询
数据库·mysql
帷幄庸者8 小时前
跨网的Kubernetes集群:从零构建混合云架构
容器·架构·kubernetes
bepeater12348 小时前
使用Kubernetes部署Spring Boot项目
spring boot·容器·kubernetes
harrain8 小时前
windows下载安装MySQL9.5的缺少Redistributable问题解决
windows·mysql
终生成长者9 小时前
Kubernetes常用操作与概念总结--从服务器导出mongo数据,并下载到本地
服务器·容器·kubernetes
chlk12310 小时前
聊聊索引:为何 B + 树能撑起数据库的半壁江山?
数据库·mysql