HAProxy是一个使用C语言编写的自由及开放源代码软件,其提供高可用性、负载均衡,以及基于TCPHTTP的应用程序代理。

HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中,同时可以保护你的web服务器不被暴露到网络上。

HAProxy实现了一种事件驱动, 单一进程模型,此模型支持非常大的并发连接数。多进程或多线程模型受内存限制 、系统调度器限制以及无处不在的锁限制,很少能处理数千并发连接。事件驱动模型因为在有更好的资源和时间管理的用户空间(User-Space) 实现所有这些任务,所以没有这些问题。此模型的弊端是,在多核系统上,这些程序通常扩展性较差。这就是为什么他们必须进行优化以使每个CPU时间片(Cycle)做更多的工作。——百度百科

主机设置:

node1: 192.168.10.201  RHEL7.0  主机名:node1

node2: 192.168.10.202  RHEL7.3  主机名:node2

node3: 192.168.10.203  RHEL7.3  主机名:node3

一、node1设置

1haproxy安装【node1

[root@node1 ~]# yum install haproxy -y

2、配置haproxy

[root@node1 ~]# cd /etc/haproxy/

[root@node1 haproxy]# vim haproxy.cfg

globaldefaults段保持默认,修改frontendbackend段如下:

frontend  main *:80

    default_backend    webservers

backend webservers

    balance     roundrobin

    server      web1 192.168.10.202:80  check

    server      web2 192.168.10.203:80  check

3、记录haproxy日志,在/etc/rsyslog.conf添加:

$ModLoad imudp

$UDPServerRun 514

local2.*      /var/log/haproxy.log

图片.png

重启rsyslog

[root@node1 ~]# systemctl restart rsyslog

二、node2node3设置

1、安装httpd

# yum install httpd -y

2、测试页:

[root@node2 ~]# echo "<h1>node2…</h1>" > /var/www/html/index.html

[root@node3 ~]# echo "<h1>node3…</h1>" > /var/www/html/index.html

3、启动httpd服务

[root@node2 ~]# systemctl start httpd

[root@node3 ~]# systemctl start httpd

三、node1启动haproxy

[root@node1 haproxy]# systemctl start haproxy

图片.png

浏览器打开:192.168.10.201node1 ip

图片.png

刷新浏览器:


分类: Linux服务

1 条评论

kimm · 2018年1月16日 下午2:46

有空就联系一下啊中铭!虽然不在同一个地方,但大家还是时常都会想起你,毕业之后我跟剑宏友斌也很少见面,但每次聚的时候都会提起你。同窗情,好基友,一辈子啊!

发表评论

电子邮件地址不会被公开。 必填项已用*标注