docker save/load以及export/import使用测试

对于有些环境需要离线安装的情况,docker以及docker容器都需要能够支持离线安装,对于docker离线安装,比较简单,按照https://www.cnblogs.com/qq931399960/p/11120429.html下载docker依赖包即可。对于docker容器或者镜像的离线安装,下面以mysql 5.7.27版本为例进行下测试。

save/load

一、按照如下方式安装并启动mysql docker容器

https://www.cnblogs.com/qq931399960/p/11341875.html

二、修改mysql容器配置参数,比如将max_connections设置为2000

三、将当前mysql容器保存为一个新的镜像(镜像是只读的,我们不能够修改镜像。如果不保存当前镜像,而且直接save之前默认的镜像,则参数max_connections的值不会是2000)

格式:

docker commit containerID repository:tag

四、将新保存的镜像save到本地

格式

docker save imageID -o saveImageName.tar 或者
docker save imageID > saveImageName.tar

五、加载镜像,当前使用了一台虚拟机进行测试,为了效果明显,先停止并删除已经保存到本地IMAGE ID为58197de028a9的容器和镜像

加载镜像格式

docker load -i saveImageName.tar 或者
docker load < saveImageName.tar

我们发现,只导入了一层数据,这是由于docker镜像是分层的,我们系统中已经存在一个从docker.io/mysql库中获取到的mysql,并且我们当前导入的容器是在其基础上生成,docker使用公共的mysql容器的分层,只加载了不同的分层。如果我们将原有的mysql镜像都删除,则每层都会加载,由于我们做了修改,故会新加一层,及上图中大小12.29k的最后一个层。

可以发现,这里有12层,比之前默认下载的5.7.27版本多了一层。

六、解决镜像REPOSITORYTAGnone问题

通过docker images可以发现IMAGE IDSIZE都与之前一致,但REPOSTIORYTAG显示为none

解决此问题,需要使用到docker tag命令

格式

docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG] 或者
docker tag IMAGEID TARGET_IMAGE[:TAG]   

七、验证

根据新导入的镜像,启动mysql容器

docker run --name mysqltest -p 3306:3306 -e MYSQL_ROOT_PASSWORD=12345 -d mysql:5.7.27

查看mysqlmax_connections配置是否为2000,为2000,则镜像导出导入正确

docker exec -it mysqltest mysql -uroot -p;
show variables like '%max_connections%';

export/import

 停止已启动的mysql容器并删除,删除所有mysql镜像,重新安装mysql 5.7.27版本,并设置max_connections的值为2000

一、导出容器

格式

docker export CONTAINER ID|NAME -o container_name.tar

二、导入容器(可直接导入到当前服务器,或者下载并上传到其他服务器导入)

格式

docker import container_name.tar 或者
cat container_name.tar | docker import -repository:tag

前者导入的容器,repository和tag都为none,如果使用此方式,则需要使用tag命令修改下repository和tag,后者则对应的值分别为mysqlnew和5.7.27。导入的为容器,但导入到服务器后,变为了镜像。

三、启动新导入的镜像(mysqlnew)

按照常用方式启动(mysqltest容器名称,及3306端口已被占用)

docker run --name mysqltestnew -p 3307:3307 -e MYSQL_ROOT_PASSWORD=12345 -d mysqlnew:5.7.27

根据错误提示信息,大致可以看出来是由于命令缺失,造成启动失败,使用如下命令查看已启动的mysql所使用的command

docker ps --no-trunc

修改启动命令,并重新启动

docker run --name mysqltestnew -p 3307:3307 -e MYSQL_ROOT_PASSWORD=12345 -d mysqlnew:5.7.27 docker-entrypoint.sh mysqld

 

启动正常,登录到mysql客户端,查看max_connections的值也为2000。

 save/load和export/import区别

1、前者保存的为镜像,后者导出的为容器

2、前者导入的镜像后需要使用tag执行repository和tag,后者可以在导入的时候指定这两个参数

3、以mysql为例,前者启动时不需要添加docker-entrypoint.sh mysqld,后者则需要

4、前者导入的时候,只导入所需的层,并显示导入的进度及image id,分层导入结果很清晰,后者则只返回image id

5、前者导入的镜像大小不变,后者导入的镜像则丢失了一些历史和层数据,数据包比较小

可通过如下官方地址了解更多命令

https://docs.docker.com/engine/reference/commandline/

mysql容器启动时将数据挂载在宿主机

mysql默认数据保存地址为/var/lib/mysql,可以通过如下命令在容器启动时,将数据挂载在宿主机,这样重新生成新的镜像,save到本地后,不包含data数据(在测试一遍,另外虽然能差不多肯定如果没有挂载数据,则mysql容器中data会被save到本地,但是也需要测一下????)

docker run --name mysql_test -p 3306:3306 -e MYSQL_ROOT_PASSWORD=12345 -v /docker/mysql/data:/var/lib/mysql -d mysql:5.7.27
原文地址:https://www.cnblogs.com/qq931399960/p/11379252.html