Docker-数据卷管理

Docker-数据卷管理

1.利用数据卷和数据容器管理数

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

Docker 的数据卷,它是一个目录,但并不属于容器 UFS 的一部分,它只是在主机上被绑定挂载(bind mount) 到容器的一个普通目录.

1.1 数据卷

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

需求:宿主机目录/var/www挂载到容器中的/data1。

注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。
docker run -it --name test02 -v /var/www:/data centos:latest
#-v选项可以在容器内创建数据卷,/var/www 是宿主机目录       /data1 是容器目录

ls
echo "this file from docker test02" >> /data/test.txt
exit

#返回宿主机进行查看
ls /var/www
test.txt

cat /var/www/test.txt
this file from docker test02

image-20220707191745311

1.2 数据卷容器

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

需求:创建数据卷容器

#创建一个容器作为数据卷容器
docker run -it --name test03 -v /data1 -v /data2 centos:latest bash	      #创建并进入容器
echo "this is test file" > /data1/test.txt							#容器内创建测试文件1
echo "THIS IS TEST FILE" > /data2/TEST.txt							#容器内创建测试文件1

#使用--volumes-from来挂载test2容器中的数据卷到新的容器
docker run -it --name test04 --volumes-from test03 centos:latest bash	#创建并进入容器
cat data1/test.txt													#查看测试数据是否同步
cat data2/TEST.txt

image-20220707192748661

2.容器互联

容器互联是通过容器的名称在容器间建立一条专门的网络通信隧道。简单点说,就是会在源容器和接收容器之间建立一条隧道,接收容器可以看到源容器指定的信息。

#创建并运行源容器取名web1
docker run -itd -P --name web1 centos:latest /bin/bash
#创建并运行接收容器取名web2,使用--link选项指定连接容器以实现容器互联
docker run -it -P --name web2 --link web1:web1 centos:latest /bin/bash			#--link容器名:连接的别名

#进web2容器,ping web1
docker exec -it web2 bash
ping web1

默认情况下,无论容器之间是否已经建立了显式连接,都可以互相通信。如果想要防止尚未连接的容器能够互联,可以在启动 Docker 守护进程时加上 --icc=false 和 --iptables 这两个参数。当容器之间建立了连接时,Docker 便会设置 iptables 规则让容器可以在已声明为开放(exposed)的端口上进行通信。

遗憾的是,Docker 的连接功能目前还有一些不足之处。其中最大的不足也许就是连接只能是静态的。虽然连接在容器重启之后应该还能工作,但如果目标容器被替换了,连接是不会更新的。此外,目标容器必须在主容器之前启动,这意味着双向连接是不可能的

image-20220707193434181

posted @ 2022-07-07 19:46  残-云  阅读(46)  评论(0编辑  收藏  举报