docker部署mysql的问题:docker commit 后的镜像没有数据

发布时间 2023-06-30 15:12:16作者: 买定灬离手

问题:带有表及数据的mysql容器, docker commit  提交后 容器中的  /var/lib/mysql/ 中的 文件是没有被提交到镜像中的 ,打包成镜像之后,数据丢失。

解决办法:

1、需要 修改mysql容器的数据目录  在根目录下  新建目录  mdkir  /data  
2、 将 /var/lib/mysql    复制 到新建目录中
3、 修改  /etc/mysql/mysql.conf.d/mysqld.cnf
datadir = /data/mysql  
4、退出 容器
5、重新 将该容器  commit 为新 的镜像, 再打开新容器就可以了

docker exec -it mysql  bash 
mkdir /data
mv var/lib/mysql   /data/
#查看一下 datadir		= /var/lib/mysql   这行的行号
cat -n /etc/mysql/mysql.conf.d/mysqld.cnf
#由于没有 vi 命令  所以用 sed 命令把这行删除
sed -i  32d  /etc/mysql/mysql.conf.d/mysqld.cnf
#在最后一行加上修改后的数据目录
echo  "datadir = /data/mysql/"  >> /etc/mysql/mysql.conf.d/mysqld.cnf