文章目录
-
- Haproxy+Nginx搭建Web集群部署
-
- 一、Haproxy概述
-
- 1、什么是Haproxy/li>
- 2、Haproxy作用
- 3、常见的Web集群调度器
- 4、Haproxy应用分析
- 5、Haproxy的特性
- 6、常见负载均衡策略
- 二、搭建Haproxy的Web集群
-
- 1、关闭防火墙
- 2、安装编译安装haproxy的依赖工具
- 3、编译安装Haproxy
- 4、Haproxy服务器配置
- 5、配置Haproxy配置文件
- 6、添加haproxy系统服务
- 7、部署nginx服务器部署(192.168.10.12,192.168.10.13)
-
- 7.1、安装部署nginxWeb服务器
- 7.2 添加 页并开启服务
- 三、验证
- 四、总结
-
- LVS、Haproxy、Nginx区别
Haproxy+Nginx搭建Web集群部署
一、Haproxy概述
1、什么是Haproxy/h4>
HAProxy 是一款提供高可用性、负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理软件,支持虚拟主机,它是免费、快速并且可靠的一种解决方案。
2、Haproxy作用
HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在时下的硬件上,完全可以支持数以万计的 并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到 络上。
3、常见的Web集群调度器
-
目前常见的Web集群调度器分为软件和硬件:
软件通常使用开源的LVS、Haproxy、Nginx。硬件一般有F5、绿盟和深信服等。
-
LVS性能最好,但是搭建相对复杂;Nginx的upstream模块支持集群功能,但是对集群节点健康检查功能不强,高并发没有Haproxy好
4、Haproxy应用分析
LVS在企业中康复在能力很强,但存在不足:
- LVS不支持正则处理,不能实现动静分离
- 对于大型 站LVS的事实配置较为复杂,维护成本相对较高
Haproxy是一款可以供高可用性、负载均衡和基于TCP和HTTP应用的代理软件:
- 适用于负载较大的Web站点
- 运行在硬件上可支持数以万计的并发连接请求
5、Haproxy的特性
- 可靠性和稳定性非常好,可以与硬件级的F5负载均衡设备相媲美
- 最高可以同时维护40000-50000个并发连接,单位时间内处理的最大请求数为20000个,最大处理能力可达10Git/s
- 支持多达8 种负载均衡算法,同时也支持会话保持
- 支持虚拟主机功能,从而实现web负载均衡更加灵活
- 支持连接拒绝、全透明代理等独特功能
- 拥有强大的ACL支持,用于访问控制
- 其独特的弹性二叉树数据结构,使数据结构的复杂性上升到了0(1),即数据的查询速度不会随着数据条目的增加而速度有所下降
- 支持客户端的keepalive功能,减少客户端与haproxy的多次三次握手导致资源量费,让多个请求在一个tcp连接中完成
- 支持TCP加速,零复制功能,类似于mmap机制
- 支持响应池(response buffering)
- 支持RDP协议
- 基于源的粘性,类似于nginx的ip_hash功能,把来自同一客户端的请求在一定时间内始终调度到上游的同一服务器
- 更好统计数据接口,其web接口显示后端冀全中各个服务器的接受、发送、拒绝、错误等数据的统计信息
- 详细的健康状态检测,web接口中有关对上流服务器的健康检测状态,并提供了一定的管理功能
- 基于流量的健康评估机制
- 基于http认证
- 基于命令行的管理接口
- 日志分析器,可对日志进行分析
6、常见负载均衡策略
Haproxy支持多种调度算法,最常用的有8种。
RR(Round Robin):
RR算法是最简单最常用的一种算法,即轮询调度。
static-rr:
表示根据权重轮询,对高性能节点提高优先级即提高权重,使高性能节点处理的更多,减轻低性能节点负担。
LC(Least Connections):
最小连接数算法,根据后端的节点连接数大小动态分配前端请求。
SH(Source Hashing):
此调度算法好处是实现会话保持,但某些IP访问量非常大时会引起负载不均衡,部分节点访问量超大,影响业务使用。
URL:
表示根据请求的URI,做cdn需使用。
url_param:
表示根据HTTP请求头来锁定每 一 次HTTP请求。
rdp—cookie(name):
表示根据据cookie (name)来锁定并哈希每一次TCP请求。
source:
表示根据请求的源IP,类似Nginx的IP hash机制。
二、搭建Haproxy的Web集群
2、安装编译安装haproxy的依赖工具
4、Haproxy服务器配置
7、部署nginx服务器部署(192.168.10.12,192.168.10.13)
7.1、安装部署nginxWeb服务器
7.2 添加 页并开启服务
四、总结
LVS、Haproxy、Nginx区别
- LVS基于Linux操作系统实现软负载均衡,而Haproxy和Nginx是基于第三方应用实现的软负载均衡
- LVS是可实现4层的IP负载均衡技术,无法实现基于目录、URL的转发。而实现Haproxy和Nginx都可以实现4层和7层技术,Haproxy可提供TCP和Http应用的负载均衡综合解决方案
- LVS因为工作在ISO模型的第四层,其状态监测功能单一,而Haproxy在状态监测方面功能更丰富、强大,可支持端口、URL、脚本等多种状态监测方式
- Haproxy功能强大,但整体性能低于4层模式的LVS负载均衡
- Nginx主要用于web服务器或缓存服务器
- Haproxy也是支持虚拟主机的
- Haproxy支持8种负载均衡器策略
- Haproxy的优点能补充nginx的一些缺点,比如支持Session的保持,Cookie的引导,同时支持通过获取指定url来检测后端服务器的状态
- Haproxy跟LVS类似,本身就只是一款负载均衡软件,单纯从效率上来讲Haproxy会比Nginx有更出色的负载均衡速度,在并发处理上也是优于Nginx的
种状态监测方式 - Haproxy支持TCP协议的负载均衡转发
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!