Docker数据管理和网络通信

Docker 的数据管理

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

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

Docker数据管理和网络通信_第1张图片

 #宿主机目录/var/www 挂载到容器中的/data1。
注意:宿主机本地目录的路径必须是使用绝对路径。如果路径不存在,Docker会自动创建相应的路径。

Docker数据管理和网络通信_第2张图片

 2.数据卷容器

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

#创建一个容器作为数据卷容器、#使用 --volumes-from 来挂载 web2 容器中的数据卷到新的容器

Docker数据管理和网络通信_第3张图片

 端口映射

在启动容器的时候,如果不指定对应的端口,在容器外是无法通过网络来访问容器内的服务。端口映射机制将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。

 #随机映射端口(从32768开始)

Docker数据管理和网络通信_第4张图片

#指定映射端口

Docker数据管理和网络通信_第5张图片

 Docker数据管理和网络通信_第6张图片

Docker数据管理和网络通信_第7张图片

 容器互联(使用centos镜像)

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

#创建并运行源容器取名test5

Docker数据管理和网络通信_第8张图片

 #创建并运行接收容器取名test6,使用--link选项指定连接容器以实现容器互联

Docker数据管理和网络通信_第9张图片

 link 容器名:连接的别名

Docker数据管理和网络通信_第10张图片

 #进test6容器, ping test5Docker数据管理和网络通信_第11张图片

 

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