docker 数据卷和数据卷容器

一 数据卷和数据卷容器

管理 Docker 容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(DataVolumes Containers)。

1.数据卷

数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于 Linux 下对目录进行的 mount 操作。

实例

将宿主机目录 /var/www 分别挂载到c1 c2容器中的 /data1,/data2
创建两个容器 并指定挂载点

docker run -itd -v /var/www:/data1 --name c1 centos:7 bash
docker run -itd -v /var/www:/data2 --name c2 centos:7 bash

在宿主机目录写入数据
cd /var/www/
echo "this is test ck" > index.html

请添加图片描述

另外开两个终端,分别登陆c1 c2容器,并查看挂载点目录里的文件
docker exec -it c1 bash 
cat  /data1/index.html 
docker exec -it c2 bash 
cat  /data2/index.html 

请添加图片描述
请添加图片描述

挂载成功的同时,而且还能实现文件共享,就比如我在c2 终端上创建一个文件 ,c1 宿主机上同样能看到
c2机
cd /data2/
echo "this is boa "> ./boa.html
c1机
cd /data1/
cat boa.html

请添加图片描述
请添加图片描述

2 数据卷容器

如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。

 创建一个容器作为数据卷容器
docker run -itd --name v1 -v /data1 -v /data2 centos:7 bash
#有data1 data2 两个挂载点目录
再创建一个容器 挂载到 数据卷容器上
 docker run -itd --name v2 --volumes-from v1 centos:7 bash

请添加图片描述
请添加图片描述

猜你喜欢

转载自blog.csdn.net/m0_75015568/article/details/130266796