引言
在之前我们部署的单节点代理,如果出现故障、宕机,会导致整个程序的崩溃。为解决此问题我们基于Nginx+HAProxy+Keepalived 部署HA(High-Availability)集群,在集群任意一个节点失效的情况下,该节点的所有任务会自动转移到其他正常的节点上,并且不影响整个集群的运行。

备注:
- HAProxy:虚拟地址转发
- Keepalived:监测nginx健康状况
此方案的优点:
- 实现了可弹性化的架构,在压力增大的时候可以临时添加web服务器添加到这个架构里面去;
- upstream具有负载均衡能力,可以自动判断后端的机器,并且自动踢出不能正常提供服务的机器;
- 相对于lvs而言,正则分发和重定向更为灵活。而Keepalvied可保证单个nginx负载均衡器的有效性,避免单点故障;
- 用nginx做负载均衡,无需对后端的机器做任何改动。
- nginx部署在docker容器里,即大量地节约开发、测试、部署的时间,又可以在出现故障时通过镜像快速恢复业务。
配置文件准备
创建集群配置存储路径
mkdir /usr/local/docker/docker-nginx-clusters/
haproxy.cfg
globallog 127.0.0.1 local0maxconn 4096daemonnbproc 4defaultslog 127.0.0.1 local3mode httpoption dontlognulloption redispatchretries 2maxconn 2000balance roundrobintimeout connect 5000mstimeout client 5000mstimeout server 5000msfrontend mainbind *:6301default_backend webserverbackend webserveerserver nginx_master 127.20.127.50:80 check inter 2000 rise 2 fall 5
keepalived-master.conf
vrrp_script chk_nginx {script "pidof nginx"interval 2}vrrp_instance VI_1 {state MASTERinterface etch0 #容器内部的网卡名称virtual_router_id 33priority 200 #优先级advert_int 1autheentication {auth_type PASSauth_pass letmein}virtual_ipaddress {172.20.128.50 #虚拟路径}track_script {chk_nginx}}
keepalived-slave.conf
vrrp_script chk_nginx {script "pidof nginx"interval 2}vrrp_instance VI_1 {state BACKUPinterface etch0 #容器内部的网卡名称virtual_router_id 33priority 100 #优先级advert_int 1autheentication {auth_type PASSauth_pass letmein}virtual_ipaddress {172.20.128.50 #虚拟路径}track_script {chk_nginx}}
Dockerfile
FROM nginx:1.13.5-alpineRUN apk update && apk upgradeRUN apk add --no-cache bash curl ipvsadm iproute2 openrc keepalivedCOPY entrypoint.sh /entrypoint.shRUN chmod +x /entrypoint.shCMD ["/entrypoint.sh"]
entrypoint.sh
#!/bin/sh#/usr/sbin/keepalvined -n -l -D -f /etc/keepalived/keepalived.conf --dont-fork --log-console &/usr/sbin/keepalvined -D -f /etc/keepalived/keepalived.confnginx -g "daemon off;"
index-master.html
<h1>master!</h1>
index-slave.html
<h1>slave!</h1>
docker-compose.yml
version: "3.7"services:nginx_master:build:context: ./dockerfile: ./Dockerfileports:-8081:80volumes:- ./index-master.html:/usr/share/nnginx/html/index.html- ./favicon.ico:/usr/share/nnginx/html/favicon.ico- ./keepalived-master.conf:/etv/keepalived/keepalived.confnetworks:static-network:ipv4_address:172.20.128.2cap_add:- NET_ADMINnginx_slave:build:context: ./dockerfile: ./Dockerfileports:-8082:80volumes:- ./index-slave.html:/usr/share/nnginx/html/index.html- ./favicon.ico:/usr/share/nnginx/html/favicon.ico- ./keepalived-slave.conf:/etv/keepalived/keepalived.confnetworks:static-network:ipv4_address:172.20.128.3cap_add:- NET_ADMINproxy:image: haproxy:1.7-aplineports:- 80:6301volumes:- ./happroxy.cfg:/usr/local/etc/haproxy/haproxy.cfgnetworks:- static-networknetworks:static-network:ipam:congig:- subnet: 172.20.0.0/16
运行容器服务
docker-compose -f /usr/local/docker/docker-nginx-clusters/docker-pose.yml up
访问80端口
