haproxy简介
-
HAProxy提供负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费、快速并且可靠的一种解决方案。
-
HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。
-
HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。
-
HAProxy实现了一种事件驱动, 单一进程模型,此模型支持非常大的并发连接数。多进程或多线程模型受内存限制 、系统调度器限制以及无处不在的锁限制,很少能处理数千并发连接。事件驱动模型因为在有更好的资源和时间管理的用户空间(User-Space) 实现所有这些任务,所以没有这些问题。此模型的弊端是,在多核系统上,这些程序通常扩展性较差。这就是为什么他们必须进行优化以 使每个CPU时间片(Cycle)做更多的工作。
centos7中安装haproxy
yum安装:
HAProxy 已经包含在 yum 的base中,版本为1.15,可以直接yum安装
yum install -y haproxy
HAProxy的配置文件路径为:/etc/haproxy/haproxy.cfg
主程序路径为:/usr/sbin/haproxy
源码安装:
下载安装包:haproxy-1.5.18.tar.gz
# 上传到服务器中,解压:
tar -zxvf haproxy-1.5.18.tar.gz
# 进入解压后的目录中:
cd haproxy-1.5.18
# 安装
make TARGET=linux2628 ARCH=x86_64 PREFIX=/usr/local/haproxy
make install PREFIX=/usr/local/haproxy
#参数说明
TARGET=linux26 # 内核版本,使用 uname -r 查看内核,如:2.6.18-371.el5,此时该参数就为linux26;kernel 大于2.6.28的用:TARGET=linux2628
ARCH=x86_64 # 系统位数
PREFIX=/usr/local/haprpxy # /usr/local/haprpxy为haprpxy 安装路径
编辑配置文件
如:
vim /usr/local/haproxy/haproxy.cfg
global
daemon
log 127.0.0.1 local3 info
maxconn 1000
ulimit-n 4000
nbproc 1
pidfile /tmp/haproxy.pid
defaults
timeout connect 5000ms
timeout client 50000ms
timeout server 50000ms
frontend http-in-unstable
mode tcp
bind *:12001
default_backend httpunstable
backend httpunstable
server server1 192.168.149.152:12001 maxconn 3000
frontend http-in-unstable_12002
mode tcp
bind *:12002
default_backend httpunstable_12002
backend httpunstable_12002
server server1 192.168.149.152:12002 maxconn 3000