HAProxy 负载均衡配置
![]() | ![]() | ![]() | ![]() |
| 【性价之王】 | 【线路之王】 | 【价格之王】 | 【配置之王】 |
| 【免费之王】 | 【香港首推】 | 【梯子之王】 | 【独服之王】 |
一、HAProxy简介HAProxy是一种高效、可靠、免费的高可用及负载均衡解决方案,非常适合于高负载站点的七层数据请求。(HAProxy可以基于四层和七层提供TCP和HTTP(select mode,根据报文内容)应用的负载均衡综合解决方案。)因为HAProxy实现了一种事件驱动、单一进程模型,此模型支持非常大的并发连接数。
客户端通过HAProxy代理服务器获得站点页面,而代理服务器收到客户请求后根据负载均衡的规则将请求数据转发给后端真实服务器。HAProxy还支持Session的保持和Cookie的引导。
同一客户端访问服务器,HAProxy保持会话的三种方案:
1、 HAProxy将客户端ip进行Hash计算并保存,由此确保相同IP访问时被转发到同一真实服务器上。( 配置:balance source)
2、 HAProxy依靠所使用的服务器发送给客户端的cookie信息进行会话保持。
3、 HAProxy保存所使用的服务器的session及服务器标识,实现会话保持功能。
二、HAProxy工作原理HAProxy有前端(frontend)和后端(backend),前端和后端都可以有多个。也可以只有一个listen块来同时实现前端和后端。这里主要讲一下frontend和backend工作模式。 前端(frontend)区域可以根据HTTP请求的header信息来定义一些规则,然后将符合某规则的请求转发到相应后端(backend)进行处理。因此HAProxy可以实现动静分离(动静分离简单来说就是指将静态请求转发到对应的静态资源服务器,将动态请求转发到动态资源服务器)
三、HAProxy配置文件修改haproxy的主配置文件 vim /etc/haproxy/haproxy.cfg(haproxy不处理SSL时,mode应为tcp)
| vim /etc/haproxy/haproxy.cfg | |
| #修改内容如下: | |
| frontend main | |
| bind *:80 | |
| default_backend webservers | |
| backend webservers | |
| balance roundrobin | |
| server app1 192.168.1.105:80 check | |
| server app2 192.168.1.106:80 check |
轮询调度(Round Robin Scheduling)算法就是以轮询的方式依次将请求调度不同的服务器,即每次调度执行i = (i + 1) mod n,并选出第i台服务器。
算法的优点是其简洁性,它无需记录当前所有连接的状态,所以它是一种无状态调度。仅有两台服务器的话,会在两台服务器间轮流转发请求。
会话保持的第一种方法:基于source算法,确保相同IP访问时被转发到同一真实服务器上。
Source算法| 1)把balance调度算法改为source: | |
| vim /etc/haproxy/haproxy.cfg | |
| backend webservers | |
| balance source | |
| #自于同一IP的请求,始终定向至同一台 |
| 1)把balance调度算法改为uri: | |
| vim /etc/haproxy/haproxy.cfg | |
| backend webservers | |
| balance uri | |
| server app1 192.168.1.105:80 check | |
| server app2 192.168.1.106:80 check | |
| #uri的机制,对同一个uri(资源)的请求,始终定义至同一个server上。无论从哪个客户端访问test1.html, 都指向的是web2上面的test1.html;无论从哪个客户端访问test2.html, 都指向的是web1上面的test2.html,与客户端IP无关,与每个服务端请求次数无关,与使用的客户端类型无关。 |
也就是我们在简介中提到的第二种设置会话保持的方法,HAProxy依靠真实服务器发送给客户端的cookie信息(也就是浏览器端的缓存信息中会包含服务器的node信息, 如web1 或者 是web2, 从而该浏览器下次访问时还会访问之前访问过的web服务器。)进行会话保持。
| vim /etc/haproxy/haproxy.cfg | |
| --- | |
| backend webserver | |
| cookie node insert nocache | |
| stats enable | |
| server web1 ip1:port check node1 | |
| server web2 ip2:port check node2 | |
| --- | |
| #重载haproxy | |
| systemctl reload haproxy |
配置haproxy动静分流
LOADING
配置haproxy域名分流(SNI,Server Name Indication)(SSL)
LOADING
五、HAProxy后端web服务器状态检测(灾备)HAProxy有三种状态检测方式:
1).基于四层的传输端口做状态监测
2).基于指定的uri做状态监测
3).基于指定的URI的resquest请求头部内容做状态监测
1. 基于四层的传输端口做状态监测
通过监听端口进行健康检测。这种检测方式,haproxy检查后端server的端口,并不能保证服务的真正可用。有时候服务端口监听和进程都是存在的,不代表正常提供服务,这时使用基于端口的监听方式明显就不太合适了。
| vim /etc/haproxy/haproxy.cfg | |
| #inter 时间间隔 | |
| --- | |
| backend webserver | |
| balance roundrobin | |
| cookie HAPROXY-COOKIE insert indirect nocache | |
| server web1 ip1:port check port xx addr ip inter 3000 fail 3 rise 5 | |
| server web2 ip2:port check port xx addr ip inter 3000 fail 3 rise 5 | |
| --- | |
| #重载haproxy | |
| systemctl reload haproxy |
2. 基于指定的uri做状态监测
用GET后端server的的web页面,基本上可以代表后端服务的可用性。模拟客户端去访问服务端,如果响应码是正常的说明服务端处于正常工作状态,避免了基于端口监控的弊端。
| vim /etc/haproxy/haproxy.cfg | |
| --- | |
| listen webserver | |
| mode http | |
| bind *:80 | |
| balance roundrobin | |
| cookie HAPROXY-COOKIE insert indirect nocache | |
| option httpchk GET / URI | |
| server web1 ip1:port check cookie node1 check | |
| server web2 ip2:port check port xx addr ip inter 3000 fail 3 raise 5 | |
| --- | |
| #重载haproxy | |
| systemctl reload haproxy |
3. 基于指定的URI的resquest请求头部内容做状态监测
抛弃消息体(body)部分,只返回给haproxy响应头部(head)信息即可,节省了后端web服务器的网络I/O。
#LOADING[linux]历史优惠活动内容
猜你可能想看的VPS
- 双十一 iON→2 核 CPU 4G 内存套餐 新加坡 洛杉矶机房 月付全球[VPS测评]
- WordPress 后台更新升级出现"您确定要这样做?"的解决办法全球[VPS测评]
- Indirect modification of overloaded 全球[VPS测评]
- 疯狂猜成语 图猜成语一个老头和进化论的图片是什么成语?全球[VPS测评]
- HostYun 圣何塞双程 GIA VPS 速度及综合性能测评,100M全球[VPS测评]
- 免费 SSL 证书汇总收集整理全球[VPS测评]
- wget 下载 https 时报错 ERROR: The certifi全球[VPS测评]
- 一般般-标准互联→襄阳电信 5G 防御款 2 核 4G 70G 硬盘 1全球[VPS测评]
- $15 年 512M 内存 10G 硬盘 1T 流量 1Gbps KVM全球[VPS测评]
- 真实测评 修罗云→洛杉矶 CN2 GIA 线路 1G 内存方案测评数据全球[VPS测评]
- 微基主机 IDC.WIKI→美国 CN2 虚拟主机 日本 CN2 VPS日本VPS[主机]
- 极客主机→49 元 月 KVM-1GB 20GB 300GB 拉斯维加斯全球[VPS测评]
- imidc→e3 e5 独服 120 台 $30 月 香港服务器 台湾服日本VPS[主机]
- 真实测评 CombCloud 香港沙田 CN2- 4H4G 80GSSD香港VPS[主机]
- Hostodo 亚洲优化线路512MB内存8gNVME硬盘 3T大流量 全球[VPS测评]
- Host Liberty-4.95欧元 月 美国 加拿大 新加坡 德国等美国VPS[主机]
- Mansora 2018圣诞优惠全球[VPS测评]
- 跨境电商洋码头生死攸关:买手流失资金被冻结保全全球[VPS测评]
- 什么是Bootstrap?全球[VPS测评]
- 六一云:香港CMI VPS,10G防御,1核/1G/40G SSD/15香港VPS[主机]
- 云计算的大门依旧没向雷军敞开全球[VPS测评]
- 海量科技:香港2核2G云服务器,5M独享带宽,低至168元/月香港VPS[主机]
- 腾讯会议故障了 提示:会议发生异常请重新加入会议全球[VPS测评]
- 做跨境电商一个月都有多少收入?全球[VPS测评]
- 众创逸云:1核2G云服务器,不限流量vps/5Mbps/KVM/香港CN香港VPS[主机]
- 快速云:科普云服务器服务器的概念和作用2022-08-2313:26来源全球[VPS测评]
- GreenCloudVPS:5折、6折优惠,日本、新加坡、香港等KVM 日本VPS[主机]
- HostKVM香港云地VPS,2核4G内存折后$8.4/月,30M大带宽香港VPS[主机]
- 快速云:云服务器和vps区别是什么云服务器和vps哪个比较安全2022-全球[VPS测评]
- wordpress 上传附件报错 “抱歉,出于安全的考虑,不支持此文件类全球[VPS测评]
转载请注明原文地址:http://140.238.13.167:12355/read-228787.html











