需求
有一个web应用的项目,单独部署在容器里,对于部署的主机开放端口(例如3000, 或者3080)。然后我们希望考虑到项目的高可用性,尝试使用负载均衡的解决方案。
实现效果
我们在多台主机上跑这个容器,也可能是同一个主机上跑多个容器,只要端口不冲突即可,然后使用haproxy,配置相关的文件,当其中一台容器或者一个主机挂了之后,haproxy会自动选择可用的服务,使得整个项目服务具有高可用性。
实践
环境
- 主机1:192.168.85.129,部署了一个容器,开放端口为3000。
- 主机2:192.168.85.128,部署了两个容器,开放端口为3000和3080.
- 主机3:运行haproxy,可检测相关主机的现象
操作记录
以下操作主要是在主机3中进行。主机3的操作系统为ubuntu14.04.
- 安装Haproxy1.5
sudo add-apt-repository ppa:vbernat/haproxy-1.5
sudo apt-get update
sudo apt-get</