赞
踩
目录
web集群调度器分为软件和硬件
HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。
Haproxy的特性
其中,常用的调度算法有三种
RR(RounderRobin)轮询
LC(LeastConnection)最少连接数,根据后端的节点连接数大小动态分配前端请求
SH(Source Hashing)基于来源访问的调度算法,用于一些有Session会话记录在服务器端的场景,可以基于来源的IP、Cookie等做集群调度
- 1. #关闭防火墙,将安装Haproxy所需软件包传到/opt目录下
- systemctl stop firewalld
- setenforce 0
-
- cd /opt
- haproxy-1.5.18.tar.gz
-
- 2. #安装依赖软件
- yum install -y pcre-devel bzip2-devel gcc gcc-c++ make
-
- 3. #解压安装包,并切换至该软件包
- tar zxf haproxy-1.5.18.tar.gz
- cd haproxy-1.5.18/
-
- 4. #编译安装Haproxy
- 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位系统
-
- 5. #Haproxy服务器配置
- mkdir /etc/haproxy
- cp examples/haproxy.cfg /etc/haproxy/
-
- cd /etc/haproxy/
- vim haproxy.cfg
- 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.59.97:80 check inter 2000 fall 3 #定义在线节点
- server inst2 192.168.59.99:80 check inter 2000 fall 3
-
-
-
- ##########################参数说明########################
- balance roundrobin #负载均衡调度算法
- #轮询算法:roundrobin;最小连接数算法:leastconn;来源访问调度算法:source,类似于nginx的ip_hash
-
- check inter 2000 #表示haproxy服务器和节点之间的一个心跳频率
- fall3 #表示连续三次检测不到心跳频率则认为该节点失效
- 若节点配置后带有“backup”表示该节点只是个备份节点,只有主节点失效该节点才会上。不携带“backup”,表示为主节点,和其它主节点共同提供服务。
-
-
-
- 6. #添加haproxy系统服务
- cp /opt/haproxy-1.5.18/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

启动haproxy服务
准备两台已经安装nginx的服务器
192.168.112.97
修改nginx服务的主页
192.168.112.99
修改nginx服务的主页
修改完成之后,使用同网段的客户端查看结果
刷新之后,显示第二个网页
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。