-
安装服务所需的环境 :
yum install -y pcre-devel gcc gcc-c++
-
安装 Haproxy 服务 :
tar zxvf haproxy-1.5.19.tar.gz -C /opt/
cd /opt/haproxy-1.5.19/
make TARGET=linux26 #使用uname -r查看内核,如:2.6.18-371.el5,此时该参数就为linux26
make install
-
编辑 haproxy 配置文件 :
mkdir /etc/haproxy
cp examples/haproxy.cfg /etc/haproxy/ #复制配置文件到 etc下
cd /etc/haproxy/
vim haproxy.cfg
chroot /usr/share/haproxy #删除 改变根目录
redispatch #删除 强制将请求发送给已经 down 掉的服务器
listen webcluster 0.0.0.0:80 #监听所有地址的80端口
option httpchk GET /test.html #检查服务器的 test.html 文件
balance roundrobin #负载均衡使用轮询算法
server inst1 192.168.217.129:80 check inter 2000 fall 3 #指向服务器
server inst2 192.168.217.130:80 check inter 2000 fall 3
-
启动 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 #开启服务
-
Haproxy 日志管理 :(日志默认输出到syslog中 ,查看不是很方便)
vim /etc/haproxy/haproxy.cfg #修改
log /dev/log local0 info
log /dev/log local0 notice
//将这两行配置放到haproxy的global配置项目中,主要是将haproxy的info及notice日志分别记录到不同的日志文件中
service haproxy restart #重启服务
touch /etc/rsyslog.d/haproxy.conf #将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
&~ #通告日志位置
systemctl restart rsyslog.service
测试
打开客户机访问192.168.217.128/test.html ,刷新页面 ,查看两个网页是否轮流出现 。
![使用 haproxy 搭建 web 群集 使用 haproxy 搭建 web 群集](/default/index/img?u=aHR0cHM6Ly9jYWNoZS55aXN1LmNvbS91cGxvYWQvaW5mb3JtYXRpb24vMjAyMDAzMDkvMzIvMjIzNjQuanBn)
![使用 haproxy 搭建 web 群集 使用 haproxy 搭建 web 群集](/default/index/img?u=aHR0cHM6Ly9jYWNoZS55aXN1LmNvbS91cGxvYWQvaW5mb3JtYXRpb24vMjAyMDAzMDkvMzIvMjIzNjYuanBn)