解决官方mysql数据库镜像生成的容器,导入数据后重新打包数据丢失问题
转载自:https://blog.csdn.net/weixin_44277386/article/details/125652097?spm=1001.2014.3001.5502
==============
主要目的:将 docker 中的 mysql 容器打包,这个 mysql 容器中是有数据的,在打包时要求将这些数据库、表等数据一同打包。
遇到问题:容器导入数据后重新打包,数据丢失。
问题解决方法:mysql容器默认启动后将容器内/var/lib/mysql文件挂载至本地,将容器内的数据库文件夹复制到其他位置进行保存。修改mysql默认的数据库存储路径至新保存的路径即可。以下是解决步骤:
复制数据
mysql 镜像的数据默认放在 /var/lib/mysql 目录下,需要进行修改。
进入正在运行的容器,在根目录下创建 work 目录:
mkdir /work
然后复制 /var/lib/mysql 下的数据到 /work 目录下:
cp -r /var/lib/mysql /work
修改数据库配置文件
vim /etc/mysql/mysql.conf.d/mysqld.cnf
(我用的是红色字体,原文中路径是 vim /etc/mysql/my.conf)
注意:一般容器中是没有 vim 工具的,需要安装。但是直接安装不成功。需要先apt-get update,然后apt-get install -y vim。也可以不安装vim以减小容器大小,通过cp的方式进行编辑。
将这个配置文件中的 datadir 修改为刚才创建的目录:
datadir = /work/mysql
打包镜像
下一步之前可能需要重启一下 mysql 容器。
容器打包成镜像:
docker commit -m "new container" ad37a34fcb01 mysql:5.7
docker 的 commit 命令可以看菜鸟的解析:https://www.runoob.com/docker/docker-commit-command.html
这个时候得到的mysql:5.7镜像就是包含数据的镜像了。
根据镜像启动一个容器:
docker run --rm -d -it \ -p 3307:3306 \ -e MYSQL_ROOT_PASSWORD=123456 \ --name chaos-mysql mysql:5.7 \ --character-set-server=utf8mb4 \ --collation-server=utf8mb4_unicode_ci \ --default-time_zone='+8:00'
前面的主机端口号 3306 是可以改的,但是后面的 3306 一般不要改。
这个 mysql_container 容器里就是包含数据的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)