赞
踩
HAProxy是一个使用C语言编写的自由及开放源代码软件,其提供高可用性、负载均衡,以及基于TCP和HTTP的应用程序代理。
HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。
HAProxy实现了一种事件驱动, 单一进程模型,此模型支持非常大的并发连接数。多进程或多线程模型受内存限制 、系统调度器限制以及无处不在的锁限制,很少能处理数千并发连接。事件驱动模型因为在有更好的资源和时间管理的用户空间(User-Space) 实现所有这些任务,所以没有这些问题。此模型的弊端是,在多核系统上,这些程序通常扩展性较差。这就是为什么他们必须进行优化以 使每个CPU时间片(Cycle)做更多的工作。
包括 GitHub、Bitbucket、Stack Overflow、Reddit、Tumblr、Twitter和 Tuenti在内的知名网站,及亚马逊网络服务系统都使用了HAProxy。
二层负载均衡(mac)
用于虚拟mac地址方式,外部对虚拟mac地址请求,负载均衡接收后分配给后端实际的mac地址响应。
三层负载均衡(ip)
一般用于虚拟ip地址的方式,外部对虚拟ip地址请求,负载均衡接收后分配给后端实际的ip地址响应。
四层负载均衡(tcp)
在三层负载均衡的基础上,用ip+port接收请求,在转发到对应的机器上。
产品大概有:F5,lvs,nginx,haproxy…
七层负载均衡(http)
根据虚拟的url或者ip,主机名接收请求,在转发到相应的处理服务器上。
产品大概有:haproxy,nginx,apache,mysql proxy…
yum -y install haproxy
haproxy官方帮助文档:https://cbonte.github.io/haproxy-dconv/
下载安装包的地址
haproxy源码包下载网站地址:https://src.fedoraproject.org/repo/pkgs/haproxy/
//安装编译环境 [root@localhost ~]# yum -y install make gcc pcre-devel bzip2-devel openssl-devel systemd-devel //创建haproxy用户 [root@localhost ~]# useradd -r -M -s /sbin/nologin haproxy [root@localhost ~]# id haproxy uid=993(haproxy) gid=990(haproxy) groups=990(haproxy) //下载解压并安装 [root@localhost ~]# wget https://src.fedoraproject.org/repo/pkgs/haproxy/haproxy-2.1.3.tar.gz/sha512/4728c1177b2bba69465cbc56b1ed73a1b2d36891ba2d94d29bb49714ad98ccfac4b52947735aded211f0cd8070002f5406ddd77cabd2f8230b00438189dd7a60/haproxy-2.1.3.tar.gz [root@localhost ~]# tar xf haproxy-2.1.3.tar.gz [root@localhost ~]# cd haproxy-2.1.3/ [root@localhost haproxy-2.1.3]# make -j $(grep 'processor' /proc/cpuinfo |wc -l) \ > TARGET=linux-glibc \ #查看cpu核心数安装 > USE_OPENSSL=1 \ > USE_ZLIB=1 \ > USE_PCRE=1 \ > USE_SYSTEMD=1 [root@localhost haproxy-2.1.3]# make install PREFIX=/usr/local/haproxy [root@localhost haproxy-2.1.3]# cp haproxy /usr/sbin/ //设置Linux内核参数 [root@localhost haproxy-2.1.3]# vim /etc/sysctl.conf ... # For more information, see sysctl.conf(5) and sysctl.d(5). #添加如下配置 net.ipv4.ip_nonlocal_bind = 1 net.ipv4.ip_forward = 1 [root@localhost haproxy-2.1.3]# sysctl -p net.ipv4.ip_nonlocal_bind = 1 net.ipv4.ip_forward = 1 //配置haproxy服务 [root@localhost haproxy-2.1.3]# mkdir /etc/haproxy [root@localhost haproxy-2.1.3]# vim /etc/haproxy/haproxy.cfg #添加如下的内容 global log 127.0.0.1 local0 info #log loghost local0 info maxconn 20480 #chroot /usr/local/haproxy pidfile /var/run/haproxy.pid #maxconn 4000 user haproxy group haproxy daemon #--------------------------------------------------------------------- #common defaults that all the 'listen' and 'backend' sections will #use if not designated in their block #--------------------------------------------------------------------- defaults mode http log global option dontlognull option httpclose option httplog #option forwardfor option redispatch balance roundrobin timeout connect 10s timeout client 10s timeout server 10s timeout check 10s maxconn 60000 retries <
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。