Haproxy 是一个使用C语言编写的自由及开放源代码软件,其提供高可用性、负载均衡,以及基于TCP和HTTP的应用程序代理。
RR算法是最简单最常用的一种算法,即轮询调度
理解举例:有三个节点A、B、C
第一个用户访问会被指派到节点A
第二个用户访问会被指派到节点B
第三个用户访问会被指派到节点C
第四个用户访问继续指派到节点A,轮询分配访问请求实现负载均衡效果
最小连接数算法,根据后端的节点连接数大小动态分配前端请求
理解举例: 有三个节点A、B、C,各节点的连接数分别为A:4 B:5 C:6
第一个用户连接请求,会被指派到A上,连接数变为A:5 B:5 C:6
第二个用户请求会继续分配到A上,连接数变为A:6 B:5 C:6;再有新的请求会分配给B,每次将新的请求指派给连接数最小的客户端
由于实际情况下A、B、C的连接数会动态释放,很难会出现一样连接数的情况
此算法相比较rr算法有很大改进,是目前用到比较多的一种算法
基于来源访问调度算法,用于一些有Session会话记录在服务端的场景,可以基于来源的IP、Cookie等做集群调度
理解举例 有三个节点A、B、C,第一个用户第一次访问被指派到了A,第二个用户第一次访问被指派到了B
当第一个用户第二次访问时会被继续指派到A,第二个用户第二次访问时依旧会被指派到B,只要负载均衡器不重启,第一个用户都会被指派到A,第二个用户访问都会被指派到B,实现集群的调度
此调度算法好处是实现会话保持,但某些IP访问量非常大时会引起负载不均衡,部分节点访问量超大,影响业务使用
表示根据请求的URI,做cdn需使用
表示根据HTTP请求头来锁定每 一 次HTTP请求。
表示根据据cookie (name)来锁定并哈希每一次TCP请求。
表示根据请求的源IP,类似Nginx的IP hash机制。
表示根据权重,轮询
关闭防火墙
systemctl stop firewalld.service
setenforce 0
安装依赖包
yum install pcre-devel zlib-devel gcc gcc-g++ make -y
创建用户和组编译管理
useradd -M -s /sbin/nologin nginx
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-78iTcBa2-1663028742551)(F:\typorase\jpg\301.png)]](https://img-blog.csdnimg.cn/feaf6a3971a94b439654ca5cc25ba793.png)
创建nginx网络源
cd /etc/yum.repos.d/
ls
vim nginx.repo
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-c9unWnci-1663028742551)(F:\typorase\jpg\302.png)]](https://img-blog.csdnimg.cn/f9db9709e0a6424ebbaec27fb3cd192d.png)
[nginx]
name=nginx.repo
baseurl=https://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
yum clean all && yum makecache
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7XygZkPE-1663028742552)(F:\typorase\jpg\303.png)]](https://img-blog.csdnimg.cn/0c70d3e7bca54f0d9e5b3cb9916dd27f.png)
安装nginx服务
yum install -y nginx
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aHnCOaHC-1663028742552)(F:\typorase\jpg\304.png)]](https://img-blog.csdnimg.cn/3e3942094d2641d285a73d8b5b0011f7.png)
准备页面
cd /usr/share/nginx/html/
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0aYdMnlU-1663028742552)(F:\typorase\jpg\305.png)]](https://img-blog.csdnimg.cn/392a85054da2413a919af7b614be9ef1.png)
启动服务查看服务是否启动
systemctl start nginx
ss -natp |grep nginx
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vLNDq2to-1663028742552)(F:\typorase\jpg\306.png)]](https://img-blog.csdnimg.cn/d439f346abd54fb09d92517f5224499a.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-10EWZkgb-1663028742552)(F:\typorase\jpg\308.png)]](https://img-blog.csdnimg.cn/2961aa4a4de740dfa971e9813e90751c.png)
关闭防火墙
systemctl stop firewalld.service
setenforce 0
安装依赖包
yum install pcre-devel zlib-devel gcc gcc-g++ make -y
创建用户和组编译管理
useradd -M -s /sbin/nologin nginx
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qN321smg-1663028742553)(F:\typorase\jpg\301.png)]](https://img-blog.csdnimg.cn/1862de8acf4f405491f0183f8f391d91.png)
创建nginx网络源
cd /etc/yum.repos.d/
ls
vim nginx.repo
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-u2NxcWAc-1663028742553)(F:\typorase\jpg\302.png)]](https://img-blog.csdnimg.cn/f3a63f04ff61402da3bf4faa71b75387.png)
[nginx]
name=nginx.repo
baseurl=https://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
yum clean all && yum makecache
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fhJlIXSB-1663028742553)(F:\typorase\jpg\303.png)]](https://img-blog.csdnimg.cn/2e2ffe5aa72641fbbc9aa7cb689fb415.png)
安装nginx服务
yum install -y nginx
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KPOGGHfN-1663028742553)(F:\typorase\jpg\304.png)]](https://img-blog.csdnimg.cn/48c04ff61cb9457aa7338ca687752b05.png)
准备页面
cd /usr/share/nginx/html/
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GKgP4Mak-1663028742553)(F:\typorase\jpg\307.png)]](https://img-blog.csdnimg.cn/c5c27bc737b4460d95eab905656907fe.png)
启动服务查看服务是否启动
systemctl start nginx
ss -natp |grep nginx
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-scJFbDhH-1663028742554)(F:\typorase\jpg\306.png)]](https://img-blog.csdnimg.cn/aa608751f0fc4fca8ba7156e2d0c8c01.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7da4dNlH-1663028742554)(F:\typorase\jpg\309.png)]](https://img-blog.csdnimg.cn/861d674f7f664170992c3689e8158f53.png)
关闭防火墙,将安装包上传的到opt目录下
systemctl stop firewalld.service
setenforce 0
安装依赖环境
yum install -y pcre-devel bzip2-devel gcc gcc-c++ make
解压安装包
cd /opt
tar zxf haproxy-1.5.19.tar.gz
cd haproxy-1.5.19/
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Kj2LVEiF-1663028742554)(F:\typorase\jpg\310.png)]](https://img-blog.csdnimg.cn/635eb4401eab499e891b668f6ee26814.png)
编译安装Haproxy
make TARGET=linux2628 ARCH=x86_64
make install
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-32uujBSU-1663028742554)(F:\typorase\jpg\311.png)]](https://img-blog.csdnimg.cn/57d4b18452424463856a6140fc4f40b5.png)
TARGET=linux26 #内核版本,
#使用uname -r查看内核,如:2.6.18-371.el5,此时该参数用TARGET=linux26;kernel大于2.6.28的用TARGET=linux2628
ARCH=x86_64 #系统位数,64位系统
Haproxy服务器配置
mkdir /etc/haproxy
cp examples/haproxy.cfg /etc/haproxy/
cd /etc/haproxy/
vim haproxy.cfg
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Erzp13Np-1663028742554)(F:\typorase\jpg\312.png)]](https://img-blog.csdnimg.cn/968f56ed5fc443d29ac5b381ea76ea6c.png)
global
--4~5行--修改,配置日志记录,local0为日志设备,默认存放到系统日志
log /dev/log local0 info
log /dev/log local0 notice
#log loghost local0 info
maxconn 4096 #最大连接数,需考虑ulimit -n限制
--8行--注释,chroot运行路径,为该服务自设置的根目录,一般需将此行注释掉
#chroot /usr/share/haproxy
uid 99 #用户UID
gid 99 #用户GID
daemon #守护进程模式
defaults
log global #定义日志为global配置中的日志定义
mode http #模式为http
option httplog #采用http日志格式记录日志
option dontlognull #不记录健康检查日志信息
retries 3 #检查节点服务器失败次数,连续达到三次失败,则认为节点不可用
redispatch #当服务器负载很高时,自动结束当前队列处理比较久的连接
maxconn 2000 #最大连接数
contimeout 5000 #连接超时时间
clitimeout 50000 #客户端超时时间
srvtimeout 50000 #服务器超时时间
--删除下面所有listen项--,添加
listen webcluster 0.0.0.0:80 #定义一个名为webcluster的应用
option httpchk GET /index.html #检查服务器的index.html文件
balance roundrobin #负载均衡调度算法使用轮询算法roundrobin
server inst1 192.168.116.132:80 check inter 2000 fall 3 #定义在线节点
server inst2 192.168.116.133:80 check inter 2000 fall 3
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vr7Qw3j3-1663028742555)(F:\typorase\jpg\313.png)]](https://img-blog.csdnimg.cn/528f893b4c7f46ce952e807b962e5c08.png)
# this config needs haproxy-1.1.28 or haproxy-1.2.1
global
log /dev/log local0 info
log /dev/log local1 notice
#log loghost local0 info
maxconn 4096
#chroot /usr/share/haproxy
uid 99
gid 99
daemon
#debug
#quiet
defaults
log global
mode http
option httplog
option dontlognull
retries 3
redispatch
maxconn 2000
contimeout 5000
clitimeout 50000
srvtimeout 50000
listen appli1-rewrite 0.0.0.0:80
option httpchk GET /index.html
balance roundrobin
server inst1 192.168.116.132:80 check inter 2000 fall 3
server inst2 192.168.116.133:80 check inter 2000 fall 3
添加haproxy系统服务
cp /opt/haproxy-1.5.19/examples/haproxy.init /etc/init.d/haproxy
cd /etc/init.d/
chmod +x haproxy
chkconfig --add /etc/init.d/haproxy
ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
service haproxy start
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pmIhzuj4-1663028742555)(F:\typorase\jpg\314.png)]](https://img-blog.csdnimg.cn/479ca80c59524551a326d1f8a1644787.png)
进行测试
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qiG1yYK7-1663028742555)(F:\typorase\jpg\315.png)]](https://img-blog.csdnimg.cn/685053884a1d4dfe8ec1400904180efe.png)
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6SsoFNSL-1663028742555)(F:\typorase\jpg\316.png)]](https://img-blog.csdnimg.cn/9696c792de6e4fe28e96eccdbbce38d7.png)
修改配置文件
vim /etc/haproxy/haproxy.cfg
#更改日志文件
global
log /dev/log local0 info
log /dev/log local0 notice
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MK7ATlyt-1663028742556)(F:\typorase\jpg\317.png)]](https://img-blog.csdnimg.cn/b11fcb84e0374ddc93e7d1d803afd863.png)
重启haproxy服务
service haproxy restart
为了便于管理将haproxy相关的配置独立定义到haproxy.conf
vim /etc/rsyslog.d/haproxy.conf
if ($programname == 'haproxy' and $syslogseverity-text == 'info')
then -/var/log/haproxy/haproxy-info.log
&~
if ($programname == 'haproxy' and $syslogseverity-text == 'notice')
then -/var/log/haproxy/haproxy-notice.log
&~
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y7ieyztR-1663028742556)(F:\typorase\jpg\318.png)]](https://img-blog.csdnimg.cn/5dc24e7928a147eea40e8956bee85318.png)
重启haproxy服务
systemctl restart rsyslog.service
service haproxy restart
tail -f /var/log/haproxy/haproxy-info.log
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4hKmGhBv-1663028742556)(F:\typorase\jpg\319.png)]](https://img-blog.csdnimg.cn/9cb3818b99fb42aa92a2269c356a1893.png)
停止掉某个节点服务器,然后再刷新页面,开启节点服务器,则会产生haproxy-notice.log文件
tail -f /var/log/haproxy/haproxy-notice.log
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KWaC1WHa-1663028742556)(F:\typorase\jpg\320.png)]](https://img-blog.csdnimg.cn/cc924cd5f378442e83a7146fe6519219.png)