Haproxylinux
简介:web
HAProxy提供高可用性、负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费、快速而且可靠的一种解决方案。安全
HAProxy特别适用于那些负载特大的web站点,这些站点一般又须要会话保持或七层处理。bash
HAProxy运行在当前的硬件上,彻底能够支持数以万计的并发链接。而且它的运行模式使得它能够很简单安全的整合进您当前的架构中, 同时能够保护你的web服务器不被暴露到网络上。服务器
HAProxy实现了一种事件驱动, 单一进程模型,此模型支持很是大的并发链接数。多进程或多线程模型受内存限制 、系统调度器限制以及无处不在的锁限制,不多能处理数千并发链接。事件驱动模型由于在有更好的资源和时间管理的用户空间(User-Space) 实现全部这网络
些任务,因此没有这些问题。此模型的弊端是,在多核系统上,这些程序一般扩展性较差。这就是为何他们必须进行优化以 使每一个CPU时间片(Cycle)作更多的工做。多线程
安装:架构
#下载 wget http://fossies.org/linux/misc/haproxy-1.6.9.tar.gz #解压 tar -zxvf haproxy-1.6.9.tar.gz cd haproxy-1.6.9 #安装 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安装路径
配置:并发
【/usr/local/haproxy/haproxy.conf】负载均衡
global daemon log 127.0.0.1 local3 info maxconn 1000 ulimit-n 4000 uid 1001 #普通用户的uid和gid gid 1001 quiet quiet nbproc 1 pidfile /home/work/env/haproxy/haproxy.pid #普通用户路径权限 defaults mode tcp #协议 timeout connect 5000ms timeout client 50000ms timeout server 50000ms frontend http-in-unstable #名字 bind 43.243.130.89:1115 #本地端口 ,注本地端口防火墙也要放开 default_backend httpunstable backend httpunstable server proxy00 192.168.122.173:1115 check inter 2000 fall 3 weight 30 maxconn 1000 #外部端口(虚拟机)端口 frontend http-in-unstable_1443 bind 43.243.130.89:1443 default_backend httpunstable_1443 backend httpunstable_1443 server proxy00 192.168.122.173:1443 check inter 2000 fall 3 weight 30 maxconn 1000
启动脚本:
/home/work/env/haproxy/check_haproxy.sh #注意路径权限
#!/bin/sh dir=`dirname $(realpath $0)` selfname=`basename $0` cd $dir PID=`ps aux | grep '/usr/local/haproxy/sbin/haproxy' | grep -v grep | grep -v "$selfname" | awk '{ print $2 }'` if [ -z "$PID" ]; then /usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/conf/haproxy.conf fi