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



















