解决官方mysql镜像生成的容器,导入数据后重新打包数据丢失问题

主要目的:将 docker 中的 mysql 容器打包,这个 mysql 容器中是有数据的,在打包时要求将这些数据库、表等数据一同打包。
遇到问题:容器导入数据后重新打包,数据丢失。
问题解决方法:mysql容器默认启动后将容器内/var/lib/mysql文件挂载至本地,将容器内的数据库文件夹复制到其他位置进行保存。修改mysql默认的数据库存储路径至新保存的路径即可。以下是解决步骤:

  1. 复制数据
    mysql 镜像的数据默认放在 /var/lib/mysql 目录下,需要进行修改。
    进入正在运行的容器,在根目录下创建 work 目录:mkdir /work
    然后复制 /var/lib/mysql 下的数据到 /work 目录下:cp -r /var/lib/mysql /work

  2. 修改数据库配置文件

vim /etc/mysql/my.conf

注意:一般容器中是没有 vim 工具的,需要安装。但是直接安装不成功。需要先apt-get update,然后apt-get install -y vim。也可以不安装vim以减小容器大小,通过cp的方式进行编辑。
将这个配置文件中的 datadir 修改为刚才创建的目录:datadir = /work/mysql

  1. 打包镜像
    下一步之前可能需要重启一下 mysql 容器。

容器打包成镜像:

docker commit -a "ti" a34(mysql容器id) test_mysql:v1

docker 的 commit 命令可以看菜鸟的解析:https://www.runoob.com/docker/docker-commit-command.html

这个时候得到的 test_mysql:v1 镜像就是包含数据的镜像了。

根据镜像启动一个容器:

docker run -itd --name mysql_container  -p 3306:3306  -e MYSQL_ROOT_PASSWORD=123456 test_mysql:v1

前面的主机端口号 3306 是可以改的,但是后面的 3306 一般不要改。
这个 mysql_container 容器里就是包含数据的。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值