1、link机制介绍
同一个宿主机上的多个docker容器之间如果想进行通信,可以通过使用容器的ip地址来通信,也可以通过宿主机的ip加上容器暴露出的端口号来通信,前者会导致ip地址的硬编码,不方便迁移,并且容器重启后ip地址会改变,除非使用固定的ip,后者的通信方式比较单一,只能依靠监听在暴露出的端口的进程来进行有限的通信。通过docker的link机制可以通过一个name来和另一个容器通信,link机制方便了容器去发现其它的容器并且可以安全的传递一些连接信息给其它的容器。docker run --link可以用来链接2个容器,使得源容器(被链接的容器)和接收容器(主动去链接的容器)之间可以互相通信,本质是接收容器的/etc/hosts会添加关于源容器的dns解析,接收容器可以通过容器名/容器id/alias访问源容器,并且接收容器可以获取源容器的一些数据,如源容器的环境变量。该机制的局限是dns解析只是单项的,接收容器只能dns解析源容器,而源容器无法dns解析接收容器。
2、link使用
2.1、格式
--link <name or id>:alias
其中,name和id是源容器的name和id,alias是源容器在link下的别名
2.2、示例
源容器:
#创建并启动名为my_nginx1的容器,作为link的源容器
docker run -itd --name my_nginx1 guianjun/mynginx:v3.0 /bin/bash
接收容器:
#--link my_nginx1:nginx1,其中my_nginx1是link源容器名称,nginx1是源容器在link下的
#别名(alias),别名名称可以自定义,即my_nginx1和nginx1都是link源容器的名称,接收容器
#使用这2个名字中的哪一个都可以访问,并与link源容器进行通信
docker run -itd --name my_nginx2 --link my_nginx1:nginx1 guianjun/mynginx:v3.0 /bin/bash
对比源容器和接收容器的/etc/hosts文件:
#源容器
docker exec -it my_nginx1 cat /etc/hosts
#接收容器
docker exec -it my_nginx2 cat /etc/hosts
连通性测试:
3、link在环境变量的使用
源容器和接收容器之间传递数据是通过以下2种方式:
- 设置环境变量
- 更新/etc/hosts文件
当使用--link时,docker会自动在接收容器内创建基于--link参数的环境变量:
docker会在接收容器中设置名为<alias>_NAME的环境变量,
该环境变量的值为:<alias>_NAME=/接收容器名/源容器alias
我们进入_mynginx2容器,看下此环境变量:
docker exec -it my_nginx2 env | grep -i nginx1_name
另外,docker还会在接收容器中创建关于源容器暴露的端口号的环境变量,这些环境变量有一个统一的前缀名称:
<name>PORT<port>_<protocol>
其中:
<name>表示链接的源容器alias
<port>是源容器暴露的端口号
<protocol>是通信协议:TCP or UDP
docker用上面定义的前缀定义3个环境变量:
<name>PORT<port>_<protocol>ADDR
<name>PORT<port><protocol>PORT
<name>PORT<port><protocol>_PROTO
注意,若源容器暴露了多个端口号,则每1个端口都有上面的一组环境变量(包含3个环境变量),即若源容器暴露了4个端口号,则会有4组12个环境变量。