前言
主要参考这篇博文:https://blog.csdn.net/wjg1314521/article/details/115799943
感谢作者。
主要目的:将 docker 中的 mysql 容器打包,这个 mysql 容器中是有数据的,在打包时要求将这些数据库、表等数据一同打包。
问题解释:这里直接贴原博文的解释:
1. 复制数据
mysql 镜像的数据默认放在 /var/lib/mysql
目录下,需要进行修改。
进入正在运行的容器,在根目录下创建 work 目录:mkdir /work
。
然后复制 /var/lib/mysql 下的数据到 /work 目录下:cp -r /var/lib/mysql /work
。
2. 修改数据库配置文件
vim /etc/mysql/mysql.conf.d/mysqld.conf
一般容器中是没有 vim 工具的,需要安装。但是直接安装不成功。需要先apt-get update
,然后apt-get install vim
。
将这个配置文件中的 datadir 修改为刚才创建的目录:datadir = /work/mysql
。
3. 打包镜像
下一步之前可能需要重启一下 mysql 容器。
打包:
docker commit -a "hanson" a404c6c174a2(mysql容器id) mymysql:v1
docker 的 commit 命令可以看菜鸟的解析:https://www.runoob.com/docker/docker-commit-command.html
这个时候得到的 mymysql:v1 镜像就是包含数据的镜像了。
根据镜像启动一个容器:
docker run -itd --name mymysql-1 -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mymysql:v1
前面的主机端口号 3307 是可以改的,但是后面的 3306 一般不要改,反正我一改就错。
这个 mymysql-1 容器里就是包含数据的。