一、何为数据卷容器?
命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据的共享,此时挂载了数据卷的容器被称之为数据卷容器。
二、实例演示
以上一篇(docker 容器数据卷)通过dockerfile创建的新镜像sg/centos为模板运行容器sg01/sg02/sg03,此时这些容器内都具有数据卷/dataVolumeContainer1、/dataVolumeContainer2,如下图所示,启动sg01/sg02/sg03容器:
2.1 启动父容器sg01
docker run -it --name sg01 5e0c84f8cabf //以交互式模式启动容器5e0c84f8cabf,并命名为sg01,具体如下图:
启动成功后可以看到容器内的数据卷/dataVolumeContainer1、/dataVolumeContainer2
2.2 此时我们在sg01容器中的数据卷dataVolumeContainer2中通过命令touch sg01.txt创建sg01.txt文本,具体操作如下图:
2.3 这个时候通过-volumes-from命令继承来自父容器sg01的数据卷,并以sg/centos镜像为模板实例化运行容器,最后在卷dataVolumeContainer2中创建sg02.txt文本,具体操作如下图所示:
2.4 sg03容器需要做的操作与2.3容器sg02所做操作一致,故不再重复。
2.5 此时我们通过命令docker attach 容器ID重新进入父容器sg01,并查看dataVolumeContainer2中的数据,发现sg02、sg03中创建的文本数据已经共享成功,如下图:
2.6 验证数据卷的生命周期
a. 删除父容器sg01,并在容器sg02中的数据卷dataVolumeContainer中修改文本,最后在容器sg03中验证数据还能否共享,如下图所示,证明数据依然可以共享
b.继上一步操作以后,再删除sg02,然后进入sg03容器,查看数据卷中的数据还能否访问,如下图所示,可知数据依然可以共享
c. 再进一步新建sg04容器继承sg03,然后删除sg03,可知数据依然能够共享。这个就不验证了。上班了。
docker run -it --name sg04 --volumes-from sg03 sg/centos //以sg/centos镜像为模板,并继承容器sg03的数据卷,实例化一个名为sg04的容器。
综上可得:容器之间配置信息的传递,数据卷的生命周期会一直持续到没有容器使用它为止。