HAProxy提供高可用性、负载平衡以及基于TCP和HTTP应用的署理,支持虚拟主机,软件开发,它是免费、快速而且靠得住的一种办理方案,包罗Twitter,Reddit,StackOverflow,GitHub在内的多家知名互联网公司在利用。HAProxy实现了一种事件驱动、单一历程模子,此模子支持很是大的并发毗连数。
安装HAProxy
首先需要去HAProxy的官网下载HAProxy的安装文件,今朝最新的版本为:haproxy-1.7.8.tar.gz。下载地点为http://www.haproxy.org/#down,相关文档地点为http://www.haproxy.org/#doc1.7。
将haproxy-1.7.8.tar.gz拷贝至/opt目次下,与RabbitMQ存放在同一个目次中。之后解压缩:
[root@node1 opt]# tar zxvf haproxy-1.7.8.tar.gz
将源码解压之后,需要运行make来将HAProxy编译为可执行措施。在执行make之前需要先选择方针平台,凡是对付UNIX系的操纵系统可以选择TARGET=generic。下面是具体操纵:
[root@node1 opt]# cd haproxy-1.7.8
[root@node1 haproxy-1.7.8]# make TARGET=generic
gcc -Iinclude -Iebtree -Wall -O2 -g -fno-strict-aliasing -Wdeclaration-after-statement -fwrapv
-DTPROXY -DENABLE_POLL
-DCONFIG_HAPROXY_VERSION=\"1.7.8\"
-DCONFIG_HAPROXY_DATE=\"2017/07/07\" \
-DBUILD_TARGET='"generic"' \
-DBUILD_ARCH='""' \
-DBUILD_CPU='"generic"' \
-DBUILD_CC='"gcc"' \
-DBUILD_CFLAGS='"-O2 -g -fno-strict-aliasing -Wdeclaration-after-statement -fwrapv"' \
-DBUILD_OPTIONS='""' \
-c -o src/haproxy.o src/haproxy.c
gcc -Iinclude -Iebtree -Wall -O2 -g -fno-strict-aliasing -Wdeclaration-after-statement -fwrapv...
...
gcc -g -o haproxy src/haproxy.o src/base64.o src/protocol.o src/uri_auth.o ...
编译完目次下有名为“haproxy”的可执行文件。之后再/etc/profile中插手haproxy的路径,软件开发,内容如下:
export PATH=$PATH:/opt/haproxy-1.7.8/haproxy
最后执行source /etc/profile让此情况变量生效。
设置HAProxy
HAProxy利用单一设置文件来界说所有属性,包罗从前端IP到后端处事器。下面展示了用于3个RabbitMQ节点构成集群的负载平衡设置。这3个节点的IP地点别离为192.168.02、192.168.0.3、192.168.0.4,HAProxy运行在192.168.0.9这台呆板上。
#全局设置
global
#日志输出设置,软件开发,所有日志都记录在本机,通过local0输出
log 127.0.0.1 local0 info
#最大毗连数
maxconn 4096
#改变当前的事情目次
chroot /opt/haproxy-1.7.8
#以指定的UID运行haproxy历程
uid 99
#以指定的GID运行haproxy历程
gid 99
#以守护历程方法运行haproxy #debug #quiet
daemon
#debug
#当前历程pid文件
pidfile /opt/haproxy-1.7.8/haproxy.pid
#默认设置
defaults
#应用全局的日志设置
log global
#默认的模式mode{tcp|http|health}
#tcp是4层,http是7层,health只返回OK
mode tcp
#日志种别tcplog
option tcplog
#不记录康健查抄日志信息
option dontlognull
#3次失败则认为处事不行用
retries 3
#每个历程可用的最大毗连数
maxconn 2000
#毗连超时
timeout connect 5s
#客户端超时
timeout client 120s
#处事端超时
timeout server 120s
#绑定设置
listen rabbitmq_cluster 5671
#设置TCP模式
mode tcp
#简朴的轮询
balance roundrobin
#RabbitMQ集群节点设置
server rmq_node1 192.168.0.2:5672 check inter 5000 rise 2 fall 3 weight 1
server rmq_node2 192.168.0.3:5672 check inter 5000 rise 2 fall 3 weight 1
server rmq_node3 192.168.0.4:5672 check inter 5000 rise 2 fall 3 weight 1
#haproxy监控页面地点
listen monitor :8100
mode http
option httplog
stats enable
stats uri /stats
stats refresh 5s
在上面的设置中“listen rabbitmq_cluster bind 192.168.0.9.5671”这里界说了客户端毗连IP地点和端标语。这里设置的负载平衡算法是roundrobin,留意这里的roundrobin是加权轮询。和RabbitMQ最相关的是“ server rmq_node1 192.168.0.2:5672 check inter 5000 rise 2 fall 3 weight 1”这种,它界说了RabbitMQ处事,每个RabbitMQ处事界说指令包括6个部门:
server <name>:界说RabbitMQ处事的内部标示,留意这里的“rmq_node”是指包括有寄义的字符串名称,不是指RabbitMQ的节点名称。 <ip>:<port>:界说RabbitMQ处事的毗连的IP地点和端标语。 check inter <value>:界说了每隔几多毫秒查抄RabbitMQ处事是否可用。 rise <value>:界说了RabbitMQ处事在产生妨碍之后,需要几多次康健查抄才气被再次确承认用。 fall <value>:界说需要经验几多次失败的康健查抄之后,HAProxy才会遏制利用此RabbitMQ处事。 weight <value>:界说了当前RabbitMQ处事的权重。