前言
今天调休在家,随便玩玩,简单做下学习记录
1. 数据卷特点
- 数据卷在容器启动时初始化,如果容器使用的镜像在挂载点包含了数据,这些数据会被拷贝到新初始化的数据卷中
- 数据卷可以在容器之间共享和重用
- 可以对数据卷里的内容直接进行修改
- 数据卷的变化不会影响镜像的更新
- 卷会一直存在,即使挂载数据卷的容器已经被删除
- 实现数据卷挂载后,停止容器,此时向宿主机写入数据,数据依然会同步到容器的对应的目录中
2. 实践
2.1 数据卷
创建数据卷
这里会在容器内的根目录下,生成两个挂载卷
FROM centos
VOLUME ["/datavolume1","/datavolume2"]
CMD /bin/bash
构建
docker build -t=“volume” .
启动构建的容器,将宿主机/home/weiheng/dockertest/volumeData 目录挂载到容器的两个挂载点上
docker run --name volumeTest -v /home/weiheng/dockertest/volumeData:/datavolume1 -v /home/weiheng/dockertest/volumeData:/datavolume2 -it volume /bin/bash
可以看到容器里两个挂在卷是正常存在的
我们 exit 退出容器,在宿主机的挂载目录里创建文件
可以看到,宿主机里创建的文件,在容器的两个挂在卷都生成了
在datavolume2中创建文件bb,
在datavolume1和宿主机挂载目录中,会同时生成文件bb
2.2 数据卷容器
命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据卷的容器,就叫做数据卷容器
docker run --volumes-from [容器名]
接前面2.1的内容
我们新启动一个容器,挂载到 volumeTest容器的数据卷
docker run --name newVolume --volumes-from volumeTest -itd volume /bin/bash
可以看到,新启动的容器里也有同名的挂在卷,有相同的文件
在新容器newVolume中创建文件,在挂载容器volumeTest中实现了数共享,在宿主机目录下也做了数据同步
由此,我们可以实现多个容器的数据共享