Docker提供了多个容器直接访问的方法,最简单的方式是直接使用端口映射-p
参数指定映射的端口或者-P
映射所有端口,多个容器直接通过网络端口进行访问。
但网络端口映射方式并不是Docker中连接多个容器的唯一方式,更安全的方法是可以使用Docker的连接系统(--link
)连接多个容器,当容器连接到一起时,接受者容器就可以看到源容器的信息。
以Tomcat + Mysql为例,建立容器之间的连接
在容器直接建立连接要使用--link
选项
--link <name or id>:alias
这里我们通过建立一个 Tomcat + Mysql 的服务,示例一下如何在两个或者多个容器之间建立连接。
要建立容器连接的话,就要依赖容器的名字了,使用--name
指定源容器的名字为mysql
docker run --name mysql -d gsoft/mysql:5.6
接下来创建tomcat容器,并且连接到mysql容器上去
docker run --name tomcat -d -p 80:8080 --link mysql:mysql gsoft/tomcat:7.0
这里通过--link
选项指定了要连接的容器是mysql。
容器互通信息
建立两个容器之间的连接之后,在接收容器(Recipient)中必然会需要访问源容器(Source)的资源,我们在为容器建立连接时,源容器在创建时并没有使用-p/-P
指定要暴露出来的端口,因此如何访问源容器的信息呢?
为了可以让接收容器能够访问源容器的信息,Docker提供了两种方式:
- 环境变量
- /etc/hosts文件
环境变量
Docker在连接容器的时候,会根据--link
提供的参数自动的在接收者容器中创建一些环境变量,包括源容器的Dockerfile
中使用ENV
命令设置的环境变量和源容器启动时(docker run
),使用-e
或者--env
, --env-file
参数指定的环境变量。
主要包含以下环境变量,这里假设alias=mysql。
<alias>_PORT
<alias>_PORT_<port>_<protocol>
<alias>_PORT_<port>_<protocol>_ADDR
<alias>_PORT_<port>_<protocol>_PORT
<alias>_PORT_<port>_<protocol>_PROTO
<alias>_NAME
例如:
#docker run -i -t --rm --link mysql:mysql ubuntu:14.04 env PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin HOSTNAME=9c74aa611463 TERM=xterm MYSQL_PORT=tcp://172.17.0.3:3306 MYSQL_PORT_3306_TCP=tcp://172.17.0.3:3306 MYSQL_PORT_3306_TCP_ADDR=172.17.0.3 MYSQL_PORT_3306_TCP_PORT=3306 MYSQL_PORT_3306_TCP_PROTO=tcp MYSQL_NAME=/desperate_ritchie/mysql HOME=/root
上述例子中,指定了容器的别名为msyql,因此所有环境变量都是以
MYSQL_
开头。
注意的是,如果源容器重启,接收容器中的环境变量信息并不会自动更新,因此,如果要使用源容器的IP地址,请使用/etc/hosts中配置的主机信息。
/etc/hosts文件
除了环境变量之外,Docker也在接收容器的/etc/hosts
文件中更新了hosts信息。
# docker run -i -t --rm --link mysql:mysql ubuntu:14.04 /bin/bash # cat /etc/hosts 127.0.0.1 localhost ::1 localhost ip6-localhost ip6-loopback fe00::0 ip6-localnet ff00::0 ip6-mcastprefix ff02::1 ip6-allnodes ff02::2 ip6-allrouters 172.17.0.3 mysql 115346bdb403 172.17.0.5 09bdf7805133
从上可以看出,在接收容器的hosts文件中增加了两条额外的信息,本机IP和别名以及源容器的IP和别名(mysql)。
与环境变量不同的是,如果源容器重启了,接收容器中/etc/hosts
中的信息会自动更新。