目录
一、Docker数据管理介绍
二、数据卷
1、数据卷概念
三、数据卷容器
1、数据卷容器的概念
2、数据卷容器示例
四、容器互联
1、容器互联概念
2、容器互联示例
一、Docker数据管理介绍
-
用户在使用Docker的过程中,往往需要能查看容器内应用产生的数据,或者需要把容器内的数据进行备份,甚至多个容器之间进行数据的共享,这必然涉及容器的数据管理操作。
-
容器中管理数据主要有两种方式:
- 数据卷(Data Volumes)
- 数据卷容器(Data Volume Dontainers)
二、数据卷
1、数据卷概念
数据卷是一个供容器使用的特殊目录,位于容器中。可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。数据卷的使用类似于Linux下对目录进行的mount操作。
示例一
docker pull centos:7 #拉取一个centos7镜像
宿主机目录/var/www挂载到容器中的/data1
注意:宿主机本地目录的路径必须是使用绝对路径,如果路径不存在,Docker会自动创建相应的路径。
docker run -v /var/www:/data1 --name test1 -it centos:7 /bin/bash
#创建容器并将宿主机的/var/www目录挂载到容器test1中的/data1中,运行容器,并以bash的shell环境进入
cd data1/
echo "this is the test1 web" > /data1/index.html #写入一个新文件
#写入新文件后,回到宿主机本地目录查看是否有新文件产生
示例二
新创建一个容器,将宿主机/opt下的hello.txt文件挂载到容器中的/opt目录下的bye.txt文件
docker run -v /opt/hello.txt:/opt/bye.txt --name test2 -it centos:7 /bin/bash
#将宿主机/opt下的hello.txt文件挂载到容器中的/opt目录下名称为bye.txt的文件
PS:无论是宿主机中目录与容器中目录挂载,还是宿主机中文件与容器中文件挂载,数据卷均可以成功进行挂载与数据的同步,在使用 docker run -v 命令时要注意"宿主机目录/文件:容器目录/文件"的格式,目录的格式为“ ///”,文件的格式为“ //”。
三、数据卷容器
1、数据卷容器的概念
如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器是一个普通的容器,专门提供数据卷给其他容器挂载使用。
2、数据卷容器示例
#创建一个容器作为数据卷容器
docker run -id --name test1 -v /data1 -v /data2 centos:7
#将目录/data1与/data2作为数据卷进行共享
docker run -id --name test2 --volumes-from test1 centos:7
docker run -id --name test3 --volumes-from test1 centos:7
#新创建两个容器都与挂载数据卷到数据卷容器test1进行共享
作者:五彩斑斓黑
链接:https://juejin.cn/post/7195434522584809509
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
#如何设置新建容器对于数据卷容器目录只读
docker run -id --name test4 --volumes-from test1:ro centos:7
#在数据卷容器后方使用“:”符号添加只读权限(read only)
四、容器互联
1、容器互联概念
容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。
2、容器互联示例
docker run -id --name test1 centos:7
#创建一个新容器
docker run -id --name test2 --link test1:ping1 centos:7
#创建新容器,使用--link互联test1容器,ping1为test1的别名