HAProxy介绍

(1)HAProxy 是一款提供高可用性、负载均衡以及基于TCP(第四层)和HTTP(第七层)应用的代理软件,支持虚拟主机,它是免费、快速并且可靠的一种解决方案。 HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。HAProxy运行在时下的硬件上,完全可以支持数以万计的 并发连接。并且它的运行模式使得它可以很简单安全的整合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。

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

(3)HAProxy 支持连接拒绝 : 因为维护一个连接的打开的开销是很低的,有时我们很需要限制攻击蠕虫(attack bots),也就是说限制它们的连接打开从而限制它们的危害。 这个已经为一个陷于小型DDoS攻击的网站开发了而且已经拯救了很多站点,这个优点也是其它负载均衡器没有的。

(4)HAProxy 支持全透明代理(已具备硬件防火墙的典型特点): 可以用客户端IP地址或者任何其他地址来连接后端服务器. 这个特性仅在Linux 2.4/2.6内核打了cttproxy补丁后才可以使用. 这个特性也使得为某特殊服务器处理部分流量同时又不修改服务器的地址成为可能。

性能,HAProxy借助于OS上几种常见的技术来实现性能的最大化:

(1)单进程、事件驱动模型显著降低了上下文切换的开销及内存占用。

(2)O(1)事件检查器(event checker)允许其在高并发连接中对任何连接的任何事件实现即时探测。

(3)在任何可用的情况下,单缓冲(single buffering)机制能以不复制任何数据的方式完成读写操作,这会节约大量的CPU时钟周期及内存带宽。

(4)借助于Linux 2.6 (>= 2.6.27.19)上的splice()系统调用,HAProxy可以实现零复制转发(Zero-copy forwarding),在Linux 3.5及以上的OS中还可以实现零复制启动(zero-starting)。

(5)内存分配器在固定大小的内存池中可实现即时内存分配,这能够显著减少创建一个会话的时长。

(6)树型存储:侧重于使用作者多年前开发的弹性二叉树,实现了以O(log(N))的低开销来保持计时器命令、保持运行队列命令及管理轮询及最少连接队列。

(7)优化的HTTP首部分析:优化的首部分析功能避免了在HTTP首部分析过程中重读任何内存区域。

(8)精心地降低了昂贵的系统调用,大部分工作都在用户空间完成,如时间读取、缓冲聚合及文件描述符的启用和禁用等。

所有的这些细微之处的优化实现了在中等规模负载之上依然有着相当低的CPU负载,甚至于在非常高的负载场景中,5%的用户空间占用率和95%的系统空间占用率也是非常普遍的现象,这意味着HAProxy进程消耗比系统空间消耗低20倍以上。因此,对OS进行性能调优是非常重要的。即使用户空间的占用率提高一倍,其CPU占用率也仅为10%,这也解释了为何7层处理对性能影响有限这一现象。由此,在高端系统上HAProxy的7层性能可轻易超过硬件负载均衡设备。

在生产环境中,在7层处理上使用HAProxy作为昂贵的高端硬件负载均衡设备故障故障时的紧急解决方案也时长可见。硬件负载均衡设备在“报文”级别处理请求,这在支持跨报文请求(request across multiple packets)有着较高的难度,并且它们不缓冲任何数据,因此有着较长的响应时间。对应地,软件负载均衡设备使用TCP缓冲,可建立极长的请求,且有着较大的响应时间。

系统环境centos7.0

 

[root@bogon ~]# uname -r
3.10.0-327.10.1.el7.x86_64

haproxy 192.168.231.129

apache  192.168.231.128:80

apache  192.168.231.130:80/8080

软件haproxy+apache做负载均衡

[root@192.168.231.128]$ apache(httpd-2.2.26)

[root@192.168.231.128]$ tar zxvf  httpd-2.2.26.tar.gz

[root@192.168.231.128]$ cd httpd-2.2.26

[root@httpd-2.2.26]$./configure --prefix=/usr/local/apache

--with-apr=/usr/local/apr-httpd/

--with-apr-util=/usr/local/apr-util-httpd/ --enable-so

--enable-mods-shared=all --with-mpm=worker

 

[root@httpd-2.2.26]$ make && make install

[root@httpd-2.2.26]$ ln -s /usr/local/apache/bin/* /usr/local/bin

[root@httpd-2.2.26]$  /usr/local/apache/bin/apachectl start

[root@httpd-2.2.26]$cat /etc/init.d/httpd

#!/bin/bash 
# 
# Startup script for the Apache Web Server 
# 
# chkconfig: - 85 15 
# description: Apache is a World Wide Web server. It is used to serve \ 
# HTML files and CGI. 
# processname: httpd 
# pidfile: /usr/local/apache/logs/httpd.pid 
# config: /usr/local/apache/conf/httpd.conf 
 
# Source function library. 
. /etc/rc.d/init.d/functions 
 
if [ -f /etc/sysconfig/httpd ]; then 
 . /etc/sysconfig/httpd 
fi 
 
# This will prevent initlog from swallowing up a pass-phrase prompt if 
# mod_ssl needs a pass-phrase from the user. 
INITLOG_ARGS="" 
 
# Path to the apachectl script, server binary, and short-form for messages. 
apachectl=/usr/local/apache/bin/apachectl 
httpd=/usr/local/apache/bin/httpd 
pid=/usr/local/apache/logs/httpd.pid 
prog=httpd 
RETVAL=0 
 
 
# The semantics of these two functions differ from the way apachectl does 
# things -- attempting to start while running is a failure, and shutdown 
# when not running is also a failure. So we just do it the way init scripts 
# are expected to behave here. 
start() { 
 echo -n $"Starting $prog: " 
 daemon $httpd $OPTIONS 
 RETVAL=$? 
 echo 
 [ $RETVAL = 0 ] && touch /var/lock/subsys/httpd 
 return $RETVAL 
}
stop() { 
 echo -n $"Stopping $prog: " 
 killproc $httpd 
 RETVAL=$? 
 echo 
 [ $RETVAL = 0 ] && rm -f /var/lock/subsys/httpd $pid 
} 
reload() { 
 echo -n $"Reloading $prog: " 
 killproc $httpd -HUP 
 RETVAL=$? 
 echo 
} 
 
# See how we were called. 
case "$1" in 
 start) 
  start 
 ;; 
 stop) 
  stop 
 ;; 
 status) 
  status $httpd 
  RETVAL=$? 
 ;; 
 restart) 
  stop 
  start 
 ;; 
 condrestart) 
 if [ -f $pid ] ; then 
 stop 
 start 
 fi 
 ;; 
 reload) 
 reload 
;; 
 graceful|help|configtest|fullstatus) 
 $apachectl $@ 
 RETVAL=$? 
 ;; 
 *)
echo $"Usage: $prog {start|stop|restart|condrestart|reload|status" 
 echo $"|fullstatus|graceful|help|configtest}" 
 exit 1 
esac 
exit $RETVAL 
启动脚本

相关文章:

  • 2021-10-15
  • 2021-08-14
  • 2022-12-23
  • 2021-06-09
  • 2022-01-17
  • 2021-06-22
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-06-19
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-09-20
  • 2021-10-06
相关资源
相似解决方案