微服务启动的时候,会自动向服务注册中心报告自己的ip和端口。但是服务是在docker容器内运行的,注册的ip就成了172开头的docker内部ip, 这个地址是无法被其它机器访问的。这种情况是不是必须手动将服务注册的地址改成宿主机的地址和端口呢,有其它好方案没----- update -----docker 1.12版本以后engine有了swarm模式,经测试使用swarm的overlay网络可解决跨主机通讯问题,这种方案是否合适呢
2 回答
斯蒂芬大帝
TA贡献1827条经验 获得超8个赞
docker swarm 提供的overlay network可以提供跨主机的容器内网络通讯,本机内容器可以在启动时指定network来组成内部网络,然后可以在swarm主机上用host模式部署nginx,使用etcd,consul等动态注册服务和更新nginx的反向代理配置来达到动态服务发现的目的。
不过overlay目前是所有跨主机通讯方式中性能损耗最大的,达到60%。网上有人做过测试,你可以找来看看。因此就目前来说,生产环境还是要考虑kubernetes或者mesos
- 2 回答
- 0 关注
- 1152 浏览
添加回答
举报
0/150
提交
取消