您现在的位置是:首页 >技术杂谈 >haproxy负载均衡+keepalived高可用网站首页技术杂谈

haproxy负载均衡+keepalived高可用

平平无奇打工仔 2023-06-20 20:00:03
简介haproxy负载均衡+keepalived高可用

LVS和haproxy、nginx做负载均衡时的区别

调度算法

LVS:轮询(rr)、加权轮询(wrr)、最少连接(lc)、加权最少连接(wlc)、源地址哈希值(sh)、目的地址哈希(dh)

haproxy:轮询(roundrobin)、加权轮询(static-rr)、最少连接(leastconn)、源地址ip(source)

uri、url_param、hdr(name)(根据http请求头)、rdp-cookie(根据客户端cookie锁定)

nginx:rr(轮询)、wrr(加权轮询)、最小连接、最短响应时间(fair)、ip_hash、uri_hash

**区别**

1、lvs是基于内核实现的软负载均衡,Nginx和haproxy是基于第三方应用实现的软负载均衡

2、lvs可实现四层负载均衡,nginx和haproxy可以实现四层和七层。haproxy可以可以提供tcp和http的综合解决方案。

3、lvs状态监控功能单一,而haproxy在状态检测方面功能更为强大,可以支持端口、url、脚本等。

4、haproxy功能强大,但是总体性能低于lvs的四层负载均衡

5、nginx主要用七层反向代理处理web服务器的网页动静分离,对于集群节点的健康检测功能不强,性能没有haproxy好。

Haproxy搭建 Web 群集

Haproxy服务器1:192.168.255.128(MASTER)  

Haproxy服务器2:192.168.255.134 (BACKUP)
Nginx服务器1:192.168.255.130
Nginx 服务器2:192.168.80.131     
客户端:192.168.255.132

一、负载均衡器

方案一 yum安装haproxy

yum -y install haproxy keepalived
vim /etc/haproxy/haproxy.cfg

 

 方案二 编译安装haproxy

yum install -y pcre-devel bzip2-devel gcc gcc-c++ make

tar zxvf haproxy-1.5.19.tar.gz
cd haproxy-1.5.19/
make TARGET=linux2628 ARCH=x86_64
make install

---------------------参数说明---------------------------------------------------------------------------
TARGET=linux26    #内核版本,
#使用uname -r查看内核,如:2.6.18-371.el5,此时该参数用TARGET=linux26;kernel大于2.6.28的用TARGET=linux2628

ARCH=x86_64     #系统位数,64位系统
----------------------------------------------------------------------------------------------------------

3.Haproxy服务器配置
mkdir /etc/haproxy
cp examples/haproxy.cfg /etc/haproxy/

cd /etc/haproxy/
vim haproxy.cfg
global        #全局配置,主要用于定义全局参数,属于进程级的配置,通常和操作系统配置有关
--4~5行--修改,定义haproxy日志输出设置和日志级别,local0为日志设备,默认存放到系统日志
        log /dev/log   local0 info        #修改
        log /dev/log   local0 notice    #修改
        #log loghost    local0 info
        maxconn 4096            #最大连接数,需考虑ulimit -n限制,推荐使用10240
--8行--注释,chroot运行路径,为该服务自设置的根目录,一般需将此行注释掉
        #chroot /usr/share/haproxy
        uid 99                    #用户UID
        gid 99                    #用户GID
        daemon                    #守护进程模式
        nbproc 1                #添加,设置并发进程数,建议与当前服务器CPU核数相等或为其2倍

defaults       #配置默认参数,这些参数可以被用到Listen,frontend,backend组件     
        log     global            #引入global定义的日志格式
        mode    http            #模式为http(7层代理http,4层代理tcp)
        option  httplog            #日志类别为http日志格式
        option  dontlognull        #不记录健康检查日志信息
        retries 3                #检查节点服务器失败次数,连续达到三次失败,则认为节点不可用
        redispatch                #当服务器负载很高时,自动结束当前队列处理比较久的连接
        maxconn 2000            #最大连接数,“defaults”中的值不能超过“global”段中的定义
        #contimeout 5000        #设置连接超时时间,默认单位是毫秒
        #clitimeout 50000       #设置客户端超时时间,默认单位是毫秒
        #srvtimeout 50000       #设置服务器超时时间,默认单位是毫秒
        timeout http-request 10s     #默认http请求超时时间
        timeout queue 1m           #默认队列超时时间
        timeout connect 10s        #默认连接超时时间,新版本中替代contimeout,该参数向后兼容
        timeout client 1m        #默认客户端超时时间,新版本中替代clitimeout,该参数向后兼容
        timeout server 1m        #默认服务器超时时间,新版本中替代srvtimeout,该参数向后兼容
        timeout http-keep-alive 10s        #默认持久连接超时时间
        timeout check 10s        #设置心跳检查超时时间


--删除下面所有listen项--,添加
listen  webcluster 0.0.0.0:80    #haproxy实例状态监控部分配置,定义一个名为webcluster的应用
        option httpchk GET /test.html    #检查服务器的test.html文件
        balance roundrobin                #负载均衡调度算法使用轮询算法roundrobin
        server inst1 192.168.10.15:80 check inter 2000 fall 3        #定义在线节点
        server inst2 192.168.10.16:80 check inter 2000 fall 3
        
---------------------参数说明---------------------------------------------------------------------------
balance roundrobin        #负载均衡调度算法
#轮询算法:roundrobin;最小连接数算法:leastconn;来源访问调度算法:source,类似于nginx的ip_hash

check inter 2000        #表示启用对此后端服务器执行健康检查,设置健康状态检查的时间间隔,单位为毫秒
fall 3                    #表示连续三次检测不到心跳频率则认为该节点失效
若节点配置后带有“backup”表示该节点只是个备份节点,仅在所有在线节点都失效该节点才启用。不携带“backup”,表示为主节点,和其它在线节点共同提供服务。
----------------------------------------------------------------------------------------------------------

4.添加haproxy 系统服务
cp /opt/haproxy-1.5.19/examples/haproxy.init /etc/init.d/haproxy
chmod +x haproxy
chkconfig --add /etc/init.d/haproxy

ln -s /usr/local/sbin/haproxy /usr/sbin/haproxy
service haproxy start    或    /etc/init.d/haproxy start

二、节点服务器(web网站服务即可)

三、keepalived高可用配置

二三步戳这里!
 

风语者!平时喜欢研究各种技术,目前在从事后端开发工作,热爱生活、热爱工作。