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

问题:带有表及数据的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 为新 的镜像, 再打开新容器就可以了

1
2
3
4
5
6
7
8
9
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

  

posted @   买定灬离手  阅读(890)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示