引言

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

image.png

备注:

  • HAProxy:虚拟地址转发
  • Keepalived:监测nginx健康状况

此方案的优点:

  1. 实现了可弹性化的架构,在压力增大的时候可以临时添加web服务器添加到这个架构里面去;
  2. upstream具有负载均衡能力,可以自动判断后端的机器,并且自动踢出不能正常提供服务的机器;
  3. 相对于lvs而言,正则分发和重定向更为灵活。而Keepalvied可保证单个nginx负载均衡器的有效性,避免单点故障;
  4. 用nginx做负载均衡,无需对后端的机器做任何改动。
  5. nginx部署在docker容器里,即大量地节约开发、测试、部署的时间,又可以在出现故障时通过镜像快速恢复业务。

配置文件准备

创建集群配置存储路径

  1. mkdir /usr/local/docker/docker-nginx-clusters/

haproxy.cfg

  1. global
  2. log 127.0.0.1 local0
  3. maxconn 4096
  4. daemon
  5. nbproc 4
  6. defaults
  7. log 127.0.0.1 local3
  8. mode http
  9. option dontlognull
  10. option redispatch
  11. retries 2
  12. maxconn 2000
  13. balance roundrobin
  14. timeout connect 5000ms
  15. timeout client 5000ms
  16. timeout server 5000ms
  17. frontend main
  18. bind *:6301
  19. default_backend webserver
  20. backend webserveer
  21. server nginx_master 127.20.127.50:80 check inter 2000 rise 2 fall 5

keepalived-master.conf

  1. vrrp_script chk_nginx {
  2. script "pidof nginx"
  3. interval 2
  4. }
  5. vrrp_instance VI_1 {
  6. state MASTER
  7. interface etch0 #容器内部的网卡名称
  8. virtual_router_id 33
  9. priority 200 #优先级
  10. advert_int 1
  11. autheentication {
  12. auth_type PASS
  13. auth_pass letmein
  14. }
  15. virtual_ipaddress {
  16. 172.20.128.50 #虚拟路径
  17. }
  18. track_script {
  19. chk_nginx
  20. }
  21. }

keepalived-slave.conf

  1. vrrp_script chk_nginx {
  2. script "pidof nginx"
  3. interval 2
  4. }
  5. vrrp_instance VI_1 {
  6. state BACKUP
  7. interface etch0 #容器内部的网卡名称
  8. virtual_router_id 33
  9. priority 100 #优先级
  10. advert_int 1
  11. autheentication {
  12. auth_type PASS
  13. auth_pass letmein
  14. }
  15. virtual_ipaddress {
  16. 172.20.128.50 #虚拟路径
  17. }
  18. track_script {
  19. chk_nginx
  20. }
  21. }

Dockerfile

  1. FROM nginx:1.13.5-alpine
  2. RUN apk update && apk upgrade
  3. RUN apk add --no-cache bash curl ipvsadm iproute2 openrc keepalived
  4. COPY entrypoint.sh /entrypoint.sh
  5. RUN chmod +x /entrypoint.sh
  6. CMD ["/entrypoint.sh"]

entrypoint.sh

  1. #!/bin/sh
  2. #/usr/sbin/keepalvined -n -l -D -f /etc/keepalived/keepalived.conf --dont-fork --log-console &
  3. /usr/sbin/keepalvined -D -f /etc/keepalived/keepalived.conf
  4. nginx -g "daemon off;"

index-master.html

  1. <h1>master!</h1>

index-slave.html

  1. <h1>slave!</h1>

docker-compose.yml

  1. version: "3.7"
  2. services:
  3. nginx_master:
  4. build:
  5. context: ./
  6. dockerfile: ./Dockerfile
  7. ports:
  8. -8081:80
  9. volumes:
  10. - ./index-master.html:/usr/share/nnginx/html/index.html
  11. - ./favicon.ico:/usr/share/nnginx/html/favicon.ico
  12. - ./keepalived-master.conf:/etv/keepalived/keepalived.conf
  13. networks:
  14. static-network:
  15. ipv4_address:172.20.128.2
  16. cap_add:
  17. - NET_ADMIN
  18. nginx_slave:
  19. build:
  20. context: ./
  21. dockerfile: ./Dockerfile
  22. ports:
  23. -8082:80
  24. volumes:
  25. - ./index-slave.html:/usr/share/nnginx/html/index.html
  26. - ./favicon.ico:/usr/share/nnginx/html/favicon.ico
  27. - ./keepalived-slave.conf:/etv/keepalived/keepalived.conf
  28. networks:
  29. static-network:
  30. ipv4_address:172.20.128.3
  31. cap_add:
  32. - NET_ADMIN
  33. proxy:
  34. image: haproxy:1.7-apline
  35. ports:
  36. - 80:6301
  37. volumes:
  38. - ./happroxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
  39. networks:
  40. - static-network
  41. networks:
  42. static-network:
  43. ipam:
  44. congig:
  45. - subnet: 172.20.0.0/16

运行容器服务

  1. docker-compose -f /usr/local/docker/docker-nginx-clusters/docker-pose.yml up

访问80端口