除了暴露端口的通信方式,还可以通过容器连接来实现容器间的通信。–link 容器名:别名
//创建一个容器
docker run -d --name dbdata training/postgres
//创建一个web容器,将其连接到dbdata上
docker run -d -P --link dbdata:db --name web training/postgres python app.py
通过docker inspect 来查看容器连接情况
“Links”: [
“/dbdata:/web/db”
],
docker给目标容器提供了2种暴露连接提供的服务
1. 环境变量
docker run --rm --name web2 --link dbdata:webdb training/webapp env
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
HOSTNAME=b34df8bc1da1
WEBDB_PORT=tcp://172.17.0.2:5432
WEBDB_PORT_5432_TCP=tcp://172.17.0.2:5432
WEBDB_PORT_5432_TCP_ADDR=172.17.0.2//地址
WEBDB_PORT_5432_TCP_PORT=5432 //端口
WEBDB_PORT_5432_TCP_PROTO=tcp //协议
WEBDB_NAME=/web2/webdb
WEBDB_ENV_PG_VERSION=9.3
HOME=/root
- /etc/hosts文件
docker run -it --rm --link dbdata:webapp --name web2 training/webapp /bin/bash
root@274229d4a8bc:/opt/webapp# 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.2 webapp 70500428e57d dbdata
172.17.0.4 274229d4a8bc
代理连接
代理连接是相对于直接连接的。直接连接是在同一台 宿主机上的,docker为了实现跨主机的容器连接提供了ambassador模式。
原来的同一宿主机容器连接:比如redis的client连接到redis的server,如果client要连接到另一台server上必须重启容器。
这种连接的缺点:不能跨宿主机,耦合性高。
代理连接:redis的client先连接到ambassador1容器上,由ambassador1通过暴露网络接口连接到server上的ambassador2容器, 而ambassador2与redis的server连接,这样就做到了客]]]]户端与服务器的解耦。
具体流程:客户机redis-client -> ambassador1->(网络)->服务器ambassador2->redis-server
举个例子:
在执行通信的时候,用的是上述顺序,在构建的时候则是,相反的。
//首先在server上创建一个redis-server
sudo docker run -d --name redis crosbymichael/redis
//启动ambassador1来连接容器redis-server并暴露网络接口给客户端来连接
sudo docker run -d --link redis:redis --name ambassador1 -p 6379:6379 ambassador
//再在client创建ambassador2
docker run -d --name ambassador2 --expose 6379 -e REDIS_PORT_6379_TCP=tcp://x.x.x.x:6379 svendowideit/ambassador
//这里的x.x.x.x是server的ip地址
//再创建一个redis-server连接ambassador2
docker run -it --rm --link ambassador2:redis relateiq/redis-cli
tony@ubuntu:~$ sudo docker run -it --rm --link ambassador2:redis relateiq/redis-cli
redis 172.17.0.2:6379> ping
PONG
redis 172.17.0.2:6379>