在CSDN上看见这篇博文感受整理的很好,就把他转过来了。这个是博主文章传送门:传送门nginx
1 硬件级的负载均衡web
常见的商用硬件负载均衡器:NetScaler、F五、Radware、Array算法
优势:后端
1)专业团队维护,可以直接经过智能交换机实现,处理能力更强,并且与系统无关,负载性能强缓存
2)更适用于一大堆设备、大访问量、简单应用安全
缺点:服务器
1)价格贵,花销大cookie
2)不能及时有效掌握服务器及应用状态,硬件负载均衡,通常都无论实际系统与应用的状态,而只是从网络层来判断,因此有时候系统处理能力已经不行了,但网络可能还将来得及反应网络
2 软件级负载均衡session
优势:性价比高,基于系统与应用的负载均衡,可以更好地根据系统与应用的情况来分配负载,适用于规模较小的网络服务
缺点:负载能力受服务器自己性能的影响,性能越好,负载能力越大
3 LVS(Linux Virtual Server)
由章文嵩博士研究的项目,使用集群技术和Linux操做系统实现一个高性能、高可用的服务器,它具备很好的
#可伸缩性(Scalability)
#可靠性(Reliability)
#可管理性(Manageability)
IP负载均衡技术:
1)VS/NAT:Virtual Server via Network Address Translation, 经过网络地址转换(Network Address Translation)将一组服务器构成一个高性能的、高可用的虚拟服务器
2) VS/TUN:Virtual Server via IP Tunneling, 经过IP隧道实现虚拟服务器的方法
3) VS/DR:Virtual Server via Direct Routing, 经过直接路由实现虚拟服务器的方法
LVS特色:
1)抗负载能力强、是工做在网络4层之上仅做分发之用,没有流量的产生,这个特色也决定了它在负载均衡软件里的性能最强的;
2)配置性比较低,这是一个缺点也是一个优势,由于没有可太多配置的东西,因此并不须要太多接触,大大减小了人为出错的概率;
3)工做稳定,自身有完整的双机热备方案,如LVS+Keepalived和LVS+Heartbeat,不过咱们在项目实施中用得最多的仍是LVS/DR+Keepalived;
4)无流量,保证了均衡器IO的性能不会收到大流量的影响;
5)应用范围比较广,能够对全部应用作负载均衡;
6)软件自己不支持正则处理,不能作动静分离,这个就比较遗憾了;其实如今许多网站在这方面都有较强的需求,这个是Nginx/HAProxy+Keepalived的优点所在
7)若是是网站应用比较庞大的话,实施LVS/DR+Keepalived起来就比较复杂了,特别后面有Windows Server应用的机器的话,若是实施及配置还有维护过程就比较复杂了,相对而言,Nginx/HAProxy+Keepalived就简单多了。
4 Nginx
Nginx(发音同 engine x)是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler(俄文:Рамблер)使用。其特色是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好
特色:
1)工做在网络的7层之上,能够针对http应用作一些分流的策略,好比针对域名、目录结构,它的正则规则比HAProxy更为强大和灵活,这也是许多朋友喜欢它的缘由之一;
2)Nginx对网络的依赖很是小,理论上能ping通就就能进行负载功能,这个也是它的优点所在;
3)Nginx安装和配置比较简单,测试起来比较方便;
4)也能够承担高的负载压力且稳定,通常能支撑超过几万次的并发量;
5)Nginx能够经过端口检测到服务器内部的故障,好比根据服务器处理网页返回的状态码、超时等等,而且会把返回错误的请求从新提交到另外一个节点,不过其中缺点就是不支持url来检测;
6)Nginx仅能支持http和Email,这样就在适用范围上面小不少,这个它的弱势;
7)Nginx不只仅是一款优秀的负载均衡器/反向代理软件,它同时也是功能强大的Web应用服务器。LNMP如今也是很是流行的web架构,大有和之前最流行的LAMP架构分庭抗争之势,在高流量的环境中也有很好的效果。
8)Nginx如今做为Web反向加速缓存愈来愈成熟了,不少朋友都已在生产环境下投入生产了,并且反映效果不错,速度比传统的Squid服务器更快,有兴趣的朋友能够考虑用其做为反向代理加速器。
5 HAProxy
HAProxy提供高可用性、负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费、快速而且可靠的一种解决方案。HAProxy特别适用于那些负载特大的web站点, 这些站点一般又须要会话保持或七层处理。HAProxy运行在当前的硬件上,彻底能够支持数以万计的并发链接。而且它的运行模式使得它能够很简单安全的整合进您当前的架构中,同时能够保护你的web服务器不被暴露到网络上。
特色:
1)HAProxy是支持虚拟主机的
2)可以补充Nginx的一些缺点好比Session的保持,Cookie的引导等工做
3)支持url检测后端的服务器出问题的检测会有很好的帮助。
4)它跟LVS同样,自己仅仅就只是一款负载均衡软件;单纯从效率上来说HAProxy更会比Nginx有更出色的负载均衡速度,在并发处理上也是优于Nginx的。
5)HAProxy能够对MySQL读进行负载均衡,对后端的MySQL节点进行检测和负载均衡,不过在后端的MySQL slaves数量超过10台时性能不如LVS,因此我向你们推荐 LVS+Keepalived。 6)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请求。