Docker 容器互联

Docker容器互联实现容器间通信

首先,大家如果看到有什么不懂的地方,欢迎吐槽!!!
我会在当天或者第二天及时回复,并且改进~~

容器的连接(linking)系统是除了端口映射以外的另一种可以与容器中应用进行交互的方式。它会在源和接收容器之间创建一个隧道,接收容器可以看到源容器指定的信息。

一、自定义容器命名
连接容器依据系统容器的名称来执行,但自定义命名容器有两个好处

  • 自定义的命名,比较好记。比如一个web应用容器,我们可以起名为web
  • 当要连接其他容器的时候,可以作为一个有用的参考点,比如连接web容器到db容器

使用–name标记可以为容器自定义命名

docker run -d --name web training/webapp
docker ps -a                                 #查看容器name
docker inspect -f "{{ .Name }}" container_id #查看容器name 

注:容器的名称是唯一的。如果已经命名了一个叫web的容器,当你要再次使用web这个名称的时候,需要先用docker rm 来删除之前创建的同名容器。
注:在执行docker run的时候如果添加–rm标记,则容器在终止运行后会立即删除。–rm 和 -d 不能同时使用
注:docker rm -f $(docker ps -qa) 删除所有存在的容器,不管是否运行中

二、容器互联
使用 –link参数可以让容器之间安全的进行交互。

docker run -d --name db 192.168.0.216:5000/postgres       #创建db容器
docker run -d -P --name web --link db:db training/webapp  #创建web容器并且link db容器 
docker exec -it web /bin/bash                             #进入web容器查看link信息 

在容器中,查看环境变量。我们可以看到关于db的link信息

root@b3ae42ca7792:/opt/webapp# env |grep -v ENV | grep 'DB_'
DB_NAME=/web/db
DB_PORT_5432_TCP_ADDR=172.17.0.92
DB_PORT=tcp://172.17.0.92:5432
DB_PORT_5432_TCP=tcp://172.17.0.92:5432
DB_PORT_5432_TCP_PORT=5432
DB_PORT_5432_TCP_PROTO=tc

在容器中,查看/etc/hosts映射文件,我们也可以看到db的信息

root@b3ae42ca7792:/opt/webapp# cat /etc/hosts | grep -v ip6
172.17.0.93 b3ae42ca7792
127.0.0.1   localhost
172.17.0.92 db 49ca543a5074

并且可以ping通db容器,说明现在web和db容器已经互联

root@b3ae42ca7792:/opt/webapp# ping 172.17.0.92
PING 172.17.0.92 (172.17.0.92) 56(84) bytes of data.
64 bytes from 172.17.0.92: icmp_seq=1 ttl=64 time=0.062 ms
64 bytes from 172.17.0.92: icmp_seq=2 ttl=64 time=0.053 ms
64 bytes from 172.17.0.92: icmp_seq=3 ttl=64 time=0.057 ms

三、通过运行容器进行查看互联信息

在下图中,我将通过参数–rm进行运行容器,并且执行命令后进行删除操作,来查看容器–link db后的信息
大家可以清楚的看到,我先运行容器,并且连接db查看env环境变量
第二条命令连接db查看/etc/hosts文件
第三条命令查看web_del容器是否存在,发现运行结束就已被删除

你可能感兴趣的:(docker)