docker容器连接

除了暴露端口的通信方式,还可以通过容器连接来实现容器间的通信。–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

  1. /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>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值