如今网站发展的趋势对网络负载均衡的使用是随着网站规模的提高根据不一样的阶段来使用不一样的技术:
一种是经过硬件来进行进行,常见的硬件有比较昂贵的NetScaler、F五、Radware和Array等商用的负载均衡器,它的优势就是有专业的维护 团队来对这些服务进行维护、缺点就是花销太大,因此对于规模较小的网络服务来讲暂时尚未须要使用;另一种就是相似于LVS/HAProxy、 Nginx的基于Linux的开源免费的负载均衡软件策略,这些都是经过软件级别来实现,因此费用很是低廉,因此我个也比较推荐你们采用第二种方案来实施 本身网站的负载均衡需求。 前端
近期朋友刘鑫(紫雨荷雪)的项目成功上线了,PV达到了亿级/日的访问量,最前端用 的是HAProxy+Keepalived双机做的负载均衡器/反向代理,整个网站很是稳定;这让我更坚决了之前跟老男孩前辈聊的关于网站架构比较合理设 计的架构方案:即Nginx/HAProxy+Keepalived做Web最前端的负载均衡器,后端的MySQL数据库架构采用一主多从,读写分离的方 式,采用LVS+Keepalived的方式。 web
在这里我也有一点要跟你们申明下:不少朋友担忧软件级别的负载均衡在高并发流量冲击下的稳定状况,事实是咱们经过成功上线的许多网站发现,它们的稳定性也 是很是好的,宕机的可能性微乎其微,因此我如今作的项目,基本上没考虑服务级别的高可用了。相信你们对这些软件级别的负载均衡软件都已经有了很深的的认 识,下面我就它们的特色和适用场合分别说明下。 算法
LVS:使用集群技术和Linux操做系统实现一个高性能、高可用的服务器,它具备很好的可伸缩性(Scalability)、可靠性(Reliability)和可管理性(Manageability),感谢章文嵩博士为咱们提供如此强大实用的开源软件。
LVS的特色是:
一、抗负载能力强、是工做在网络4层之上仅做分发之用,没有流量的产生,这个特色也决定了它在负载均衡软件里的性能最强的;
二、配置性比较低,这是一个缺点也是一个优势,由于没有可太多配置的东西,因此并不须要太多接触,大大减小了人为出错的概率;
三、工做稳定,自身有完整的双机热备方案,如LVS+Keepalived和LVS+Heartbeat,不过咱们在项目实施中用得最多的仍是LVS/DR+Keepalived;
四、无流量,保证了均衡器IO的性能不会收到大流量的影响;
五、应用范围比较广,能够对全部应用作负载均衡;
六、软件自己不支持正则处理,不能作动静分离,这个就比较遗憾了;其实如今许多网站在这方面都有较强的需求,这个是Nginx/HAProxy+Keepalived的优点所在。
七、若是是网站应用比较庞大的话,实施LVS/DR+Keepalived起来就比较复杂了,特别后面有Windows Server应用的机器的话,若是实施及配置还有维护过程就比较复杂了,相对而言,Nginx/HAProxy+Keepalived就简单多了。
Nginx的特色是:
一、工做在网络的7层之上,能够针对http应用作一些分流的策略,好比针对域名、目录结构,它的正则规则比HAProxy更为强大和灵活,这也是许多朋友喜欢它的缘由之一;
二、Nginx对网络的依赖很是小,理论上能ping通就就能进行负载功能,这个也是它的优点所在;
三、Nginx安装和配置比较简单,测试起来比较方便;
四、也能够承担高的负载压力且稳定,通常能支撑超过几万次的并发量;
五、Nginx能够经过端口检测到服务器内部的故障,好比根据服务器处理网页返回的状态码、超时等等,而且会把返回错误的请求从新提交到另外一个节点,不过其中缺点就是不支持url来检测;
六、Nginx仅能支持http和Email,这样就在适用范围上面小不少,这个它的弱势;
七、Nginx不只仅是一款优秀的负载均衡器/反向代理软件,它同时也是功能强大的Web应用服务器。LNMP如今也是很是流行的web架构,大有和之前最流行的LAMP架构分庭抗争之势,在高流量的环境中也有很好的效果。
八、Nginx如今做为Web反向加速缓存愈来愈成熟了,不少朋友都已在生产环境下投入生产了,并且反映效果不错,速度比传统的Squid服务器更快,有兴趣的朋友能够考虑用其做为反向代理加速器。
HAProxy的特色是:
一、HAProxy是支持虚拟主机的,之前有朋友说这个不支持虚拟主机,我这里特此更正一下。
二、可以补充Nginx的一些缺点好比Session的保持,Cookie的引导等工做
三、支持url检测后端的服务器出问题的检测会有很好的帮助。
四、它跟LVS同样,自己仅仅就只是一款负载均衡软件;单纯从效率上来说HAProxy更会比Nginx有更出色的负载均衡速度,在并发处理上也是优于Nginx的。
五、HAProxy能够对Mysql读进行负载均衡,对后端的MySQL节点进行检测和负载均衡,不过在后端的MySQL slaves数量超过10台时性能不如LVS,因此我向你们推荐LVS+Keepalived。
六、HAProxy的算法如今也愈来愈多了,具体有以下8种:
①roundrobin,表示简单的轮询,这个很少说,这个是负载均衡基本都具有的;
②static-rr,表示根据权重,建议关注;
③leastconn,表示最少链接者先处理,建议关注;
④source,表示根据请求源IP,这个跟Nginx的IP_hash机制相似,咱们用其做为解决session问题的一种方法,建议关注;
⑤ri,表示根据请求的URI;
⑥rl_param,表示根据请求的URl参数'balance url_param' requires an URL parameter name;
⑦hdr(name),表示根据HTTP请求头来锁定每一次HTTP请求;
⑧rdp-cookie(name),表示根据据cookie(name)来锁定并哈希每一次TCP请求。 sql