Haproxy集群部署与优化
一、常见的Web集群调度器
1、目前常见的Web集群调度器分为软件和硬件
2、软件通常使用开源的LVS、Haproxy、 Nginx
LVS性能最好,但是搭建相对复杂;Nginx 的upstream模块支持群集功能,但是对群集节点健康检查功能不强,高并发性能没有Haproxy好。
3、硬件一般使用比较多的是F5,也有很多人使用国内的一些产品,如梭子鱼、绿盟等。
二、Haproxy应用分析
1、LVS在企业应用中抗负载能力很强,但存在不足
(1)LVS不支持正则处理,不能实现动静分离
(2)对于大型网站,LVS的实施配置复杂,维护成本相对较高
2、Haproxy是一款可提供高可用性、负载均衡、及基于TCP和HTTP应用的代理的软件
(1)适用于负载大的Web站点
(2)运行在硬件上可支持数以万计的并发连接的连接请求
三、Haproxy调度算法原理
(Haproxy支持多种调度算法,最常用的有三种)
1、RR (Round Robin)
RR算法是最简单最常用的一种算法,即轮询调度
2、LC(Least Connections)
最小连接数算法,根据后端的节点连接数大小动态分配前端请求
3、SH(Source Hashing)
基于来源访问调度算法,用于一些有Session会话记录在服务器的场景,可以基于来源的IP、Cookie等做集群调度。
四、Haproxy集群部署步骤
搭建环境:
Haproxy服务器(centos7-5):192.168.177.8
Nginx服务器1(centos7-1):192.168.177.11
Nginx服务器2(centos7-8):192.168.177.18
客户端(虚拟windows7):192.168.177.200
-------------------------------------Haproxy服务器部署--------------------------------------
1、关闭防火墙,将安装Haproxy所需软件包haproxy-1.5.19.tar.gz 传到/opt目录下
systemctl stop firewalld.service
systemctl disable firewalld.service
setenforce 0