美文网首页
解决mysql镜像生成的容器,导入数据后重新打包数据丢失问题

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

作者: eiffel_加油 | 来源:发表于2022-11-09 11:51 被阅读0次

    目的:

    将 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:修改数据库配置文件

    vi /etc/mysql/my.cnf
    
    注意:一般容器中是没有 vim 工具的,需要安装。但是直接安装不成功。需要先apt-get update,然后apt-get install -y vim。也可以不安装vim以减小容器大小,通过cp的方式进行编辑。

    将这个配置文件中的 datadir 修改为刚才创建的目录:

    datadir = /work/mysql。

    步骤3:重启mysql容器

    docker restart 容器ID
    

    步骤4:打包镜像

    docker commit 容器ID mysql_image(自定义镜像名称):v1(自定义镜像版本)
    

    步骤5:启动镜像

    docker run -itd --name mysql_container -p 3306:3306 --restart=always -e MYSQL_ROOT_PASSWORD=123456 -d mysql_image:v1
    
    注:前面的主机端口号 3306 是映射宿主机的端口号,但是后面的 3306 一般不要改。这个 mysql_container 容器里就是包含数据的。

    来源:https://blog.csdn.net/weixin_44277386/article/details/125652097?spm=1001.2014.3001.5502

    相关文章

      网友评论

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

          本文链接:https://www.haomeiwen.com/subject/xgxntdtx.html