几种负载均衡策略比较_1.docx
《几种负载均衡策略比较_1.docx》由会员分享,可在线阅读,更多相关《几种负载均衡策略比较_1.docx(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、几种负载均衡策略比较PS:Nginx/LVS/HAProxy是目前使用最广泛的三种负载平衡软件,本人都在多个项目中施行过,参考了一些资料,结合本人的一些使用经历,总结一下。一般对负载平衡的使用是随着网站规模的提升根据不同的阶段来使用不同的技术。详细的应用需求还得详细分析,假如是中小型的Web应用,比方日PV小于1000万,用Nginx就完全能够了;假如机器不少,能够用DNS轮询,LVS所消耗的机器还是比拟多的;大型网站或重要的服务,且服务器比拟多时,能够考虑用LVS。一种是通过硬件来进行进行,常见的硬件有比拟昂贵的F5和Array等商用的负载平衡器,它的优点就是有专业的维护团队来对这些服务进行
2、维护、缺点就是花销太大,所以对于规模较小的网络服务来讲暂时还没有需要使用;另外一种就是类似于Nginx/LVS/HAProxy的基于Linux的开源免费的负载平衡软件,这些都是通过软件级别来实现,所以费用非常低廉。目前关于网站架构一般比拟合理流行的架构方案:Web前端采用Nginx/HAProxy+Keepalived作负载平衡器;后端采用MySQL数据库一主多从和读写分离,采用LVS+Keepalived的架构。当然要根据项目详细需求制定方案。下面讲讲各自的特点和适用场合。一、NginxNginx的优点是:1、工作在网络的7层之上,能够针对应用做一些分流的策略,比方针对域名、目录构造,它的正
3、则规则比HAProxy更为强大和灵敏,这也是它目前广泛流行的主要原因之一,Nginx单凭这点可利用的场合就远多于LVS了。2、Nginx对网络稳定性的依靠非常小,理论上能ping通就就能进行负载功能,这个也是它的优势之一;相反LVS对网络稳定性依靠比拟大,这点本人深有体会;3、Nginx安装和配置比拟简单,测试起来比拟方便,它基本能把错误用日志打印出来。LVS的配置、测试就要花比拟长的时间了,LVS对网络依靠比拟大。3、能够承当高负载压力且稳定,在硬件不差的情况下一般能支撑几万次的并发量,负载度比LVS相对小些。4、Nginx能够通过端口检测到服务器内部的故障,比方根据服务器处理网页返回的状态
4、码、超时等等,并且会把返回错误的请求重新提交到另一个节点,不过其中缺点就是不支持url来检测。比方用户正在上传一个文件,而处理该上传的节点恰好在上传经过中出现故障,Nginx会把上传切到另一台服务器重新处理,而LVS就直接断掉了,假如是上传一个很大的文件或者很重要的文件的话,用户可能会因而而不满。5、Nginx不仅仅是一款优秀的负载平衡器/反向代理软件,它同时也是功能强大的Web应用服务器。LNMP也是近几年非常流行的web架构,在高流量的环境中稳定性也很好。6、Nginx如今作为Web反向加速缓存越来越成熟了,速度比传统的Squid服务器更快,能够考虑用其作为反向代理加速器。7、Nginx可
5、作为中层反向代理使用,这一层面Nginx基本上无对手,唯一能够比照Nginx的就只要ligd了,不过ligd目前还没有做到Nginx完全的功能,配置也不那么明晰易读,社区资料也远远没Nginx活跃。8、Nginx可以作为静态网页和图片服务器,这方面的性能也无对手。还有Nginx社区非常活跃,第三方模块也很多。淘宝的前端使用的Tengine就是基于nginx做的二次开发定制版。Nginx常规的HTTP请求和响应流程图:Nginx的缺点是:1、Nginx仅能支持、s和Email协议,这样就在适用范围上面小些,这个是它的缺点。2、对后端服务器的健康检查,只支持通过端口来检测,不支持通过url来检测。
6、不支持Session的直接保持,但能通过ip_hash来解决。二、LVSLVS:使用Linux内核集群实现一个高性能、高可用的负载平衡服务器,它具有很好的可伸缩性Scalability)、可靠性Reliability)和可管理性Manageability)。LVS的优点是:1、抗负载能力强、是工作在网络4层之上仅作分发之用,没有流量的产生,这个特点也决定了它在负载平衡软件里的性能最强的,对内存和cpu资源消耗比拟低。2、配置性比拟低,这是一个缺点也是一个优点,由于没有可过多配置的东西,所以并不需要过多接触,大大减少了人为出错的几率。3、工作稳定,由于其本身抗负载能力很强,本身有完好的双机热备方
7、案,如LVS+Keepalived,不过我们在项目施行中用得最多的还是LVS/DR+Keepalived。4、无流量,LVS只分发请求,而流量并不从它本身出去,这点保证了平衡器IO的性能不会收到大流量的影响。5、应用范围比拟广,由于LVS工作在4层,所以它几乎能够对所有应用做负载平衡,包括、数据库、在线聊天室等等。LVSDR(DirectRouting)形式的网络流程图:LVS的缺点是:1、软件本身不支持正则表达式处理,不能做动静分离;而如今很多网站在这方面都有较强的需求,这个是Nginx/HAProxy+Keepalived的优势所在。2、假如是网站应用比拟庞大的话,LVS/DR+Keepa
8、lived施行起来就比拟复杂了,十分后面有Windows?Server的机器的话,假如施行及配置还有维护经过就比拟复杂了,相对而言,Nginx/HAProxy+Keepalived就简单多了。三、HAProxyHAProxy的特点是:1、HAProxy也是支持虚拟主机的。2、HAProxy的优点能够补充Nginx的一些缺点,比方支持Session的保持,Cookie的引导;同时支持通过获取指定的url来检测后端服务器的状态。3、HAProxy跟LVS类似,本身就只是一款负载平衡软件;单纯从效率上来讲HAProxy会比Nginx有更出色的负载平衡速度,在并发处理上也是优于Nginx的。4、HAP
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 负载 均衡 策略 比较 _1
限制150内