一、HAProxy简介
HAProxy是一个使用C语言编写的自由及开放源代码软件,其提供高可用性、负载均衡,以及基于TCP和HTTP的应用程序代理。HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。
HAProxy实现了一种事件驱动, 单一进程模型,此模型支持非常大的并发连接数。多进程或多线程模型受内存限制 、系统调度器限制以及无处不在的锁限制,很少能处理数千并发连接。事件驱动模型因为在有更好的资源和时间管理的用户空间(User-Space) 实现所有这些任务,所以没有这些问题。此模型的弊端是,在多核系统上,这些程序通常扩展性较差。这就是为什么他们必须进行优化以 使每个CPU时间片(Cycle)做更多的工作。包括 GitHub、Bitbucket、Stack Overflow、Reddit、Tumblr、Twitter和 Tuenti在内的知名网站,及亚马逊网络服务系统都使用了HAProxy。博文实验环境:
- 操作系统:centos7.6
- HAProxy版本:2.4.14
二、安装步骤
1、官网下载软件包
访问HAProxy官网,下载社区LTS版本,软件包大小只有3M+,下载速度比较慢。当前最新LTS版本为2.4.14。
#Linux环境安装可以选择直接下载到Linux服务器。
[root@s145 opt]# wget https://www.haproxy.org/download/2.4/src/haproxy-2.4.14.tar.gz
2、解压软件包
[root@s145 opt]# tar -zxvf haproxy-2.4.14.tar.gz
3、安装gcc编译器
[root@s145 haproxy-2.4.14]# yum install -y gcc*
4、查看操作系统内核版本
[root@s145 opt]# uname -a
Linux s145 3.10.0-957.el7.x86_64 #1 SMP Thu Nov 8 23:39:32 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux
5、编译HAProxy
#第4步主要是用于确定Linux内核,如果是centos6内核为2.6x,则TARGET=linux26。
[root@s145 haproxy-2.4.14]# make TARGET=linux31 PREFIX=/usr/local/haproxy
…
CC src/hpack-enc.o
CC src/dict.o
CC src/dgram.o
CC src/init.o
CC src/hpack-huff.o
CC src/freq_ctr.o
CC src/ebtree.o
CC src/hash.o
CC src/version.o
LD haproxy
CC dev/flags/flags.o
LD dev/flags/flags
6、源码安装
[root@s145 haproxy-2.4.14]# make install PREFIX=/usr/local/haproxy
install: creating directory ‘/usr/local/haproxy’
install: creating directory ‘/usr/local/haproxy/sbin’
…
‘doc/SPOE.txt’ -> ‘/usr/local/haproxy/doc/haproxy/SPOE.txt’
‘doc/intro.txt’ -> ‘/usr/local/haproxy/doc/haproxy/intro.txt’
7、创建配置文件
[root@s145 haproxy]# pwd
/usr/local/haproxy
[root@s145 haproxy]# mkdir conf
[root@s145 haproxy]# cd conf/
[root@s145 conf]# cp /opt/haproxy-2.4.14/examples/option-http_proxy.cfg haproxy.cfg
[root@s145 conf]# vim haproxy.cfg
8、启动HAProxy服务
[root@s145 haproxy]# /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/conf/haproxy.cfg
[WARNING] (20424) : nbproc is deprecated!
| For suffering many limitations, the ‘nbproc’ directive is now deprecated
| and scheduled for removal in 2.5. Just comment it out: haproxy will use
| threads and will run on all allocated processors. You may also switch to
| ‘nbthread 4’ to keep the same number of processors. If you absolutely
| want to run in multi-process mode, you can silence this warning by adding
| ‘nbthread 1’, but then please report your use case to developers.
9、访问虚拟主机IP验证