docker for windows的windows container下mysql的持久化

windows容器模式下的mysql持久化

1、说起来真是头疼,windows容器模式在网上根本一点东西都查不到,下面是自己摸索的一些方法。

关于挂载本地目录映射到容器中,根本不好使,容器一直是意外退出,没办法,只能想别的法子,在Dockerfile上找路子。

FROM steeltoeoss/mysql:latest
MAINTAINER xiyue
WORKDIR C:/MySQL/bin
COPY ./mysql_init.txt C:/ 
ENV Path=C:/Windows/system32;C:/Windows;C:/Windows/System32/Wbem;C:/Windows/System32/WindowsPowerShell/v1.0/;C:/Users/ContainerAdministrator/AppData/Local/Microsoft/WindowsApps;C:/MySQL/bin;
ENV MYSQL=C:/MySQL
VOLUME C:/MySQLDATA
ENTRYPOINT mysqld --init-file=C:/mysql_init.txt --console

这个镜像跟上一篇的差不多,上一篇文章将手动重置root用户的密码,这次我把这些东西写到Dockerfile中了,省一部分事情。

VOLUME是挂载容器卷,这个容器卷在docker中与本地的目录对应,具体对应的哪个目录在下面命令中查看

docker inspect mysqlContainer

2、启动容器后,容器中就有了数据卷,mysql的数据库都是存储在C:/MySQL/data下的,要持久化数据,就把这个目录下的东西复制到数据卷中,要不就直接在mysql设置中,让数据库直接存储在数据卷里。
说白了,都是需要手动去迁移,写一条复制的命令,不会的直接复制这个命令去用

xcopy C:\MySQL\data C:\MySQLDATA
发布了45 篇原创文章 · 获赞 1 · 访问量 1074

猜你喜欢

转载自blog.csdn.net/lqq404270201/article/details/103783524