docker数据卷&数据卷容器

前言

今天调休在家,随便玩玩,简单做下学习记录

1. 数据卷特点

  • 数据卷在容器启动时初始化,如果容器使用的镜像在挂载点包含了数据,这些数据会被拷贝到新初始化的数据卷中
  • 数据卷可以在容器之间共享和重用
  • 可以对数据卷里的内容直接进行修改
  • 数据卷的变化不会影响镜像的更新
  • 卷会一直存在,即使挂载数据卷的容器已经被删除
  • 实现数据卷挂载后,停止容器,此时向宿主机写入数据,数据依然会同步到容器的对应的目录中

2. 实践

2.1 数据卷

创建数据卷
这里会在容器内的根目录下,生成两个挂载卷

FROM centos
VOLUME ["/datavolume1","/datavolume2"]
CMD /bin/bash

构建

docker build -t=“volume” .

docker数据卷&数据卷容器_第1张图片
启动构建的容器,将宿主机/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 退出容器,在宿主机的挂载目录里创建文件
可以看到,宿主机里创建的文件,在容器的两个挂在卷都生成了
docker数据卷&数据卷容器_第2张图片

在datavolume2中创建文件bb,
在datavolume1和宿主机挂载目录中,会同时生成文件bb
docker数据卷&数据卷容器_第3张图片

2.2 数据卷容器

命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据卷的容器,就叫做数据卷容器

docker run --volumes-from [容器名]

接前面2.1的内容
我们新启动一个容器,挂载到 volumeTest容器的数据卷

docker run --name newVolume --volumes-from volumeTest -itd volume /bin/bash

docker数据卷&数据卷容器_第4张图片

可以看到,新启动的容器里也有同名的挂在卷,有相同的文件
docker数据卷&数据卷容器_第5张图片

在新容器newVolume中创建文件,在挂载容器volumeTest中实现了数共享,在宿主机目录下也做了数据同步

由此,我们可以实现多个容器的数据共享

你可能感兴趣的:(云原生,docker,容器,运维)