容器的连接(linking)系统是除了端口映射外,另一种跟容器中应用交互的方式。
该系统会在源和接收容器之间创建一个隧道,接收容器可以看到源容器指定的信息。
连接系统依据容器的名称来执行。因此,首先需要自定义一个好记的容器命名。
虽然当创建容器的时候,系统默认会分配一个名字。自定义命名容器有2个好处:
使用 --name
标记可以为容器自定义命名。
$ sudo docker run -d -P --name web training/webapp python app.py |
docker ps
来验证设定的命名。
$ sudo docker ps -l |
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES |
aed84ee21bde training/webapp:latest python app.py 12 hours ago Up 2 seconds 0.0.0.0:49154->5000/tcp web |
docker inspect
来查看容器的名字
$ sudo docker inspect -f "{{ .Name }}" aed84ee21bde |
/web |
docker rm
来删除之前创建的同名容器。
在执行 docker run
的时候如果添加 --rm
标记,则容器在终止后会立刻删除。注意,--rm
和 -d
参数不能同时使用。
使用 --link
参数可以让容器之间安全的进行交互。
下面先创建一个新的数据库容器。
$ sudo docker run -d --name db training/postgres |
$ docker rm -f web |
$ sudo docker run -d -P --name web --link db:db training/webapp python app.py |
--link
参数的格式为 --link name:alias
,其中 name
是要链接的容器的名称,alias
是这个连接的别名。
使用 docker ps
来查看容器的连接
$ docker ps |
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES |
349169744e49 training/postgres:latest su postgres -c '/usr About a minute ago Up About a minute 5432/tcp db, web/db |
aed84ee21bde training/webapp:latest python app.py 16 hours ago Up 2 minutes 0.0.0.0:49154->5000/tcp web |
可以看到自定义命名的容器,db 和 web,db 容器的 names 列有 db 也有 web/db。这表示 web 容器链接到 db 容器,web 容器将被允许访问 db 容器的信息。
Docker 在两个互联的容器之间创建了一个安全隧道,而且不用映射它们的端口到宿主主机上。在启动 db 容器的时候并没有使用 -p
和 -P
标记,从而避免了暴露数据库端口到外部网络上。
Docker 通过 2 种方式为容器公开连接信息:
/etc/hosts
文件
使用 env
命令来查看 web 容器的环境变量
$ sudo docker run --rm --name web2 --link db:db training/webapp env |
. . . |
DB_NAME=/web2/db |
DB_PORT=tcp://172.17.0.5:5432 |
DB_PORT_5000_TCP=tcp://172.17.0.5:5432 |
DB_PORT_5000_TCP_PROTO=tcp |
DB_PORT_5000_TCP_PORT=5432 |
DB_PORT_5000_TCP_ADDR=172.17.0.5 |
除了环境变量,Docker 还添加 host 信息到父容器的 /etc/hosts
的文件。下面是父容器 web 的 hosts 文件
$ sudo docker run -t -i --rm --link db:db training/webapp /bin/bash |
root@aed84ee21bde:/opt/webapp# cat /etc/hosts |
172.17.0.7 aed84ee21bde |
. . . |
172.17.0.5 db |
root@aed84ee21bde:/opt/webapp# apt-get install -yqq inetutils-ping |
root@aed84ee21bde:/opt/webapp# ping db |
PING db (172.17.0.5): 48 data bytes |
56 bytes from 172.17.0.5: icmp_seq=0 ttl=64 time=0.267 ms |
56 bytes from 172.17.0.5: icmp_seq=1 ttl=64 time=0.250 ms |
56 bytes from 172.17.0.5: icmp_seq=2 ttl=64 time=0.256 ms |
172.17.0.5
。
注意:官方的 ubuntu 镜像默认没有安装 ping,需要自行安装。
用户可以链接多个父容器到子容器,比如可以链接多个 web 到 db 容器上。