LVS:
1、抗负载能力强。抗负载能力强、性能高,能达到F5硬件的60%;对内存和cpu资源消耗比较低
2、工作在网络4层,通过vrrp协议转发(仅作分发之用),具体的流量由linux内核处理,因此没有流量的产生
2、稳定性、可靠性好,自身有完美的热备方案;(如:LVS+Keepalived)
3、应用范围比较广,可以对所有应用做负载均衡
4、不支持正则处理,不能做动静分离
5、支持负载均衡算法:rr(轮循)、wrr(加权轮循)、lc(最小连接)、wlc(加权最小连接)
6、配置较复杂,对网络依赖比较大,稳定性很高

Ngnix:
1、工作在网络的7层之上,可以针对http应用做一些分流的策略,比如针对域名、目录结构
2、Nginx对网络的依赖比较小,理论上能ping通就就能进行负载功能
3、Nginx安装和配置比较简单,测试起来比较方便
4、也可以承担高的负载压力且稳定,一般能支撑超过1万次的并发
5、对后端服务器的健康检查,只支持通过端口来检测,不支持通过url来检测
6、Nginx对请求的异步处理可以帮助节点服务器减轻负载
7、Nginx仅能支持http、https和E-mail协议,这样就使得其在适用范围上较窄
8、不支持Session的直接保持,但能通过ip_hash来解决。对Big request header的支持不是很好
9、支持负载均衡算法:Round-robin(轮循)、Weight-round-robin(加权轮循)、Ip-hash(Ip哈希)
10、Nginx还能做Web缓存服务器即:Cache功能

HAProxy:
1、支持两种代理模式:TCP(四层)和HTTP(七层),支持虚拟主机
2、能够补充Nginx的一些缺点比如Session的保持,Cookie的引导等工作
3、支持url检测,对后端服务器出问题的检测会有很好的帮助
4、更多的负载均衡策略比如:动态加权轮循(Dynamic Round Robin),加权源地址哈希(Weighted Source Hash),加权URL哈希和加权参数哈希(Weighted Parameter Hash)已经实现
5、单纯从效率上来讲HAProxy会比Nginx有更出色的负载均衡速度
6、HAProxy可以对Mysql进行负载均衡,对后端的DB节点进行检测和负载均衡
7、支持负载均衡算法:Round-robin(轮循)、Weight-round-robin(带权轮循)、source(原地址保持)、RI(请求URL)、rdp-cookie(根据cookie)
8、不能做Web缓存服务器即Cache

三大主流软件负载均衡器适用业务场景:
1、网站建设初期,可以选用Nigix/HAproxy作为反向代理负载均衡(或者流量不大都可以不选用负载均衡),因为其配置简单,性能也能满足一般的业务场景。如果考虑到负载均衡器是有单点问题,可以采用Nginx+Keepalived/HAproxy+Keepalived避免负载均衡器自身的单点问题。
2、网站并发达到一定程度之后,为了提高稳定性和转发效率,可以使用LVS、毕竟LVS比Nginx/HAproxy要更稳定,转发效率也更高。不过维护LVS对运维人员的要求也会更高,投入成本也更大。

注:Nginx与Haproxy比较:Nginx支持七层、用户量最大,稳定性高,比较可靠。Haproxy支持四层和七层,支持更多的负载均衡算法,支持session保存等。具体选型看使用场景,目前来说Haproxy由于弥补了一些Nginx的缺点用户量也在不断提升。

衡量负载均衡器好坏的几个重要因素:
1、会话率 :单位时间内的处理的请求数
2、会话并发能力:并发处理能力
3、数据率:处理数据能力
经过官方测试统计,haproxy 单位时间处理的最大请求数为20000个,可以同时维护40000-50000个并发连接,最大数据处理能力为10Gbps。综合上述,haproxy是性能优越的负载均衡、反向代理服务器。

总结HAProxy主要优点:
一、免费开源,稳定性也是非常好,这个可通过我做的一些小项目可以看出来,单Haproxy也跑得不错,稳定性可以与LVS相媲美;
二、根据官方文档,HAProxy可以跑满10Gbps-New benchmark of HAProxy at 10 Gbps using Myricom's 10GbE NICs (Myri-10G PCI-Express),这个作为软件级负载均衡,也是比较惊人的;
三、HAProxy可以作为MySQL、邮件或其它的非web的负载均衡,我们常用于它作为MySQL(读)负载均衡;
四、自带强大的监控服务器状态的页面,实际环境中我们结合Nagios进行邮件或短信报警,这个也是我非常喜欢它的原因之一;
五、HAProxy支持虚拟主机。

参考链接:https://www.cnblogs.com/ahang/p/5799065.html

最新文章

  1. JavaScript自学之数组排序
  2. Bootstrap<基础三> 排版
  3. Openlayers+Geoserver(一):项目介绍以及地图加载
  4. 关于plsql连接oracle数据库session失效时间设置
  5. web过滤器中获取请求的参数(content-type:multipart/form-data)
  6. c3p0参数解释
  7. JVM ,JIT ,GC RUNTIME 解析
  8. linux scp
  9. JAVA_Reflection
  10. 简单的cocos2d-x手势(转)
  11. zabbix 模版其实就是主机
  12. PE文件简单介绍
  13. 解决laydate时间日期插件定位溢出
  14. js把通过图片路径生成base64
  15. 关于Url路径中出现特殊字符,文件无法下载的问题
  16. spring Boot 出现:org.springframework.context.ApplicationContextException: Unable to start ServletWebServerApplicationContext due to missing ServletWebServerFactory bean.
  17. 修改spring源码重写classloader实现项目加密
  18. Windows IIS 使用批处理脚本自动安装与卸载
  19. vmware Harbor 复制功能试用
  20. Reading Level Assessment Using Support Vector Machines and Statistical Language Models-paper

热门文章

  1. 实现基于MYSQL验证的vsftpd虚拟用户访问
  2. 从服务间的一次调用分析整个springcloud的调用过程(二)
  3. SpringBoot自定义classloader加密保护class文件
  4. Python基础—基础数据类型int、bool、str(Day3)
  5. 依赖于angular的table组件
  6. 私有化轻量级持续集成部署方案--04-私有代码仓库服务-Gitea
  7. 微服务从代码到k8s部署应有尽有系列(五、民宿服务)
  8. AngularJS 打算开始学习
  9. 如何搭建老板想要的dashborad管理驾驶舱,这篇文章值得一看!
  10. 【C#Task】TaskCreationOptions 枚举