HAproxy+nginx 搭建负载均衡集群

本文详细介绍了如何利用HAproxy和nginx搭建Web集群,从HAproxy的基本概念、特性、负载均衡策略,到实际部署过程,包括Haproxy服务器的配置、nginx服务器的安装和httpd服务器的部署,以及集群的日志管理。文章还对比了Haproxy与LVS和Nginx的区别。
摘要由CSDN通过智能技术生成

目录

一、HAproxy 概述

1、什么是Haproxy

2、Haproxy作用

3、常见的Web集群调度器

4、Haproxy应用分析

5、Haproxy的特性

6、常见负载均衡策略

1、Haproxy支持多种调度算法,最常用的有8种。

7、nginx和LVS和Haproxy有什么区别

二、Haproxy 搭建Web群集

1、实验准备及数据流向图

2、部署Haproxy服务器

1、关闭防火墙及核心防护

2、安装依赖环境

3、上传压缩包、解压、编译安装 Haproxy

4、修改 Haproxy服务配置文件

5、 添加haproxy 系统服务

3、部署nginx服务器

1、手动安装nginx

2、配置本地源安装nginx

3、获取网络源的安装包,并安装nginx

4、部署httpd服务器

1、关闭防火墙及核心防护

2、下载httpd服务并开启

3、配置httpd服务页面文件 

4、客户端访问页面 

5、 haproxy 服务器验证

三、Haproxy集群日志重新定义

1、正常访问节点日志

2、断开节点访问日志


一、HAproxy 概述

1、什么是Haproxy

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的特性

1、可靠性和稳定性非常好,可以与硬件级的F5负载均衡设备相媲美
2、最高可以同时维护40000-50000个并发连接,单位时间内处理的最大请求数为20000个,最大处理能力可达10Git/s
3、支持多达8 种负载均衡算法,同时也支持会话保持
4、支持虚拟主机功能,从而实现web负载均衡更加灵活
5、支持连接拒绝、全透明代理等独特功能
6、拥有强大的ACL支持,用于访问控制
7、其独特的弹性二叉树数据结构,使数据结构的复杂性上升到了0(1),即数据的查询速度不会随着数据条目的增加而速度有所下降
8、支持客户端的keepalive功能,减少客户端与haproxy的多次三次握手导致资源浪费,让多个请求在一个tcp连接中完成
9、支持TCP加速,零复制功能,类似于mmap机制
10、支持响应池(response buffering)
11、支持RDP协议
12、基于源的粘性,类似于nginx的ip_hash功能,把来自同一客户端的请求在一定时间内始终调度到上游的同一服务器
13、更好统计数据接口,其web接口显示后端冀全中各个服务器的接受、发送、拒绝、错误等数据的统计信息
14、详细的健康状态检测,web接口中有关对上流服务器的健康检测状态,并提供了一定的管理功能
15、基于流量的健康评估机制
16、基于http认证
17、基于命令行的管理接口
18、日志分析器,可对日志进行分析

6、常见负载均衡策略

1、Haproxy支持多种调度算法,最常用的有8种。

① 轮询调度(Round Robin)RR

RR算法是最简单最常用的一种算法,即轮询调度。

② 权重轮询 static-rr:

对高性能节点提高优先级即提高权重,使高性能节点处理的更多,减轻低性能节点负担。

③ 最小连接数算法 LC(Least Connections)

根据后端的节点连接数大小动态分配前端请求。

④ 基于来源访问调度算法 SH(Source Hashing)

用于一些有Session会话记录在服务端的场景,可以基于哈希算法对来源的IP、Cookie等做集群调度。

此调度算法好处是实现会话保持,但某些IP访问量非常大时会引起负载不均衡,部分节点访问量超大,影响业务使用。

⑤ URL:

表示根据请求的URI,做cdn需使用。

⑥ url_param:

表示根据HTTP请求头来锁定每 一 次HTTP请求。

⑦ rdp—cookie(name)

表示根据据cookie (name)来锁定并哈希每一次TCP请求。

⑧ source:

表示根据请求的源IP,类似Nginx的IP hash机制。

7、nginx和LVS和Haproxy有什么区别

LVS

基于第三方应用实现的软负载均衡
只能实现4层的IP负载均衡技术,状态监测功能单一,但整体负载均衡性能最强

nginx

基于第三方应用实现的软负载均衡

可以实现4层和7层技术

主要用于Web服务器或缓存服务器,nginx的upstrean模块虽然也支持群集功能,但是对群集节点健康检查功能不强,性能没有Haproxy好。

Nginx主要用于web服务器或缓存服务器

Haproxy

基于linux操作系统内核实现软负载均衡
可以提供TCP和HTTP应用的负载均衡综合解决方案
在状态监测方面功能更丰富、更强大,可支持端口、URL、脚本等多种状态监测方式

Haproxy支持TCP协议的负载均衡转发

Haproxy支持8种负载均衡器策略

二、Haproxy 搭建Web群集

1、实验准备及数据流向图

Haproxy服务器  192.168.100.20

nginx1 服务器 192.168.100.30

nginx2 服务器 192.168.100.40

客户端   192.168.100.100

2、部署Haproxy服务器

1、关闭防火墙及核心防护

systemctl stop firewalld

systemctl disablle firewalld

setenforce 0

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值