容器互联
容器的链接(linking)系统是除了端口映射外,另一种在容器中应用交互的方式。该系统会在源和接收容器之间创建一个隧道,使接收容器可以看到源容器指定的信息。
自定义容器命名
为了便于连接和管理容器,可以为容器指定自定义名称:
创建带有自定义名称的容器:
$ sudo docker run -d -P --name web training/webapp python app.py
使用
docker ps
命令可以验证容器名称:$ sudo docker ps
示例输出:
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
容器链接
使用 --link
参数可以让容器之间安全地进行交互。
创建数据库容器:
$ sudo docker run -d --name db training/postgres
删除之前创建的 web 容器:
$ sudo docker rm -f web
创建新 web 容器并连接到 db 容器:
$ sudo docker run -d -P --name web --link db:db training/webapp python app.py
使用 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
aed84ee21bde training/webapp:latest python app.py 16 hours ago Up 2 minutes 0.0.0.0:49154->5000/tcp web,web/db
环境变量和 /etc/hosts 文件
Docker 通过两种方式为容器公开连接信息:
- 环境变量
- 更新 /etc/hosts 文件
查看 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_5432_TCP=tcp://172.17.0.5:5432 DB_PORT_5432_TCP_PROTO=tcp DB_PORT_5432_TCP_PORT=5432 DB_PORT_5432_TCP_ADDR=172.17.0.5
查看容器的 /etc/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
ping 测试连接:
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
本文由mdnice多平台发布
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。