Web负载均衡解决方案 HAproxy 1.4.19 发布
fmms 13年前
<div id="p_fullcontent" class="detail"> <p><a href="/misc/goto?guid=4958189176139690554" target="_blank">HAProxy</a>提供<strong>高可用性</strong>、<strong>负载均衡</strong>以及基于TCP和HTTP应用的代理,<strong>支持虚拟主机</strong>, 它是免费、快速并且可靠的一种解决方案。HAProxy特别适用于那些负载特大的web站点, 这些站点通常又需要会话保持或七层处理。HAProxy运行在当前的硬件上,完全可以支持数以万计的并发连接。并且它的运行模式使得它可以很简单安全的整 合进您当前的架构中, 同时可以保护你的web服务器不被暴露到网络上。</p> <p>下图是HAProxy的架构:</p> <p><img alt="Web负载均衡解决方案 HAproxy" src="https://simg.open-open.com/show/59e5e0ee5fbb834b2c7e5e72fcfe07ad.png" width="363" height="290" /></p> <p>下图是HAProxy的监控页面截图:</p> <p><img style="width:600px;height:438px;" alt="Web负载均衡解决方案 HAproxy" src="https://simg.open-open.com/show/94caa25293083f5fdd2982528aa91b6a.jpg" /></p> <p>HAProxy实现了一种<strong>事件驱动</strong>, <strong>单一进程</strong>模型,此模型支持非常大的并 发连接数。多进程或多线程模型受内存限制 、系统调度器限制以及无处不在的锁限制,很少能处理数千并发连接。事件驱动模型因为在有更好的资源和时间管理的用户端(User-Space) 实现所有这些任务,所以没有这些问题。此模型的弊端是,在多核系统上,这些程序通常扩展性较差。这就是为什么他们必须进行优化以 使每个CPU时间片(Cycle)做更多的工作。<br /> </p> <p>1月8日发布1.1.4.19.上一个版本是2011/09/16的1.4.18 改进:</p> <pre>2012/01/08 : 1.4.19 - MEDIUM: http: add support for sending the server's name in the outgoing request - BUG/MINOR: fix options forwardfor if-none when an alternative header name is specified - MINOR: task: new function task_schedule() to schedule a wake up - BUG/MEDIUM: checks: fix slowstart behaviour when server tracking is in use - BUG: tcp: option nolinger does not work on backends - BUG: ebtree: ebst_lookup() could return the wrong entry - BUG: http: re-enable TCP quick-ack upon incomplete HTTP requests - CLEANUP: ebtree: remove a few annoying signedness warnings - CLEANUP: ebtree: remove 4-year old harmless typo in duplicates insertion code - CLEANUP: ebtree: remove another typo, a wrong initialization in insertion code - BUG: proto_tcp: set AF_INET on tproxy for use with recent kernels - MINOR: halog: add support for matching queued requests - BUG: http: tighten the list of allowed characters in a URI 下载:http://haproxy.1wt.eu/download/1.4/src/haproxy-1.4.19.tar.gz</pre> <p></p> </div>