文章目录
1. 背景
一个项目(或者服务)由多个子项目(或者微服务)组成的,现行比较方便的是采用 docker 容器来生成微服务, 使用 docker-compose 来编排多个微服务组成整个项目。
这就涉及到了多个微服务之间的通信问题(调用与被调用)本文结合一些实践来说明下在同一台宿主机内,各容器之间的通信。
2. 最终目标
实现一个项目从 A 服务器,迁移到 B 服务器,或迁移到 C 服务器,等更多服务器上, 几乎不用修改配置文件(如修改 IP 啥的)。
3. 使用公网IP进行通信(不推荐)
- 结论: 可以实施,但不推荐。
- 优势:配置起来非常简单。
- 缺点: 容器之间的通信效率最底。如果使用了阿里云等云厂商提供有服务器,则可能会导致流量费用过高。
4. 使用内网IP进行通信(可以解决大部分人的问题了)
- 结论: 可以实施,一次部署完成后,也不迁移的情况下,可以使用。
- 优势:配置难度同公网 IP。
- 缺点:容器之间的通信效率相比公网 IP 提高很多。且不产生流量相关的费用。
- 截止到这里, 已经可以满足大部分人的需求了。