负载均衡器:LVS、Nginx、HAproxy如何选择?

news/2024/9/22 21:28:35/

目录

  • 根据流量(并发量)来选型
  • LVS
  • Nginx
  • HAProxy
  • 总结
  • 参考


实际应用中,Web 服务器集群的上层要有一台负载均衡服务器,负载均衡设备的任务就是作为 Web 服务器流量的入口,挑选最合适的一台 Web 服务器,将客户端的请求转发给它处理。

根据流量(并发量)来选型

  • 流量比较小(每日 PV 小于 100 万):使用Nginx或者Hproxy(推荐使用Nginx)。

  • 流量很大(每日 PV 大于 100 万):使用LVS。


LVS

  • LVS属于四层负载,即工作在传输层
  • 处理请求的方法:请求数据经过 LVS网络,响应数据由后端服务器的网络返回。 LVS采用的是同步转发,LVS 服务器接收到请求之后,立即 redirect 到一个后端服务器,由客户端直接和后端服务器建立连接。
  • 效率高:LVS 是 Linux 内核的一部分,直接在内核级别实现。所以LVS 具有非常高的效率和较低的延迟
  • 性能佳:由于在内核级别实现,LVS 能够处理非常高的并发连接数
  • 配置简单:配置相对简单,但功能较少。通常与其他工具(如 Keepalived)结合使用来实现高可用性和管理。
  • 扩展性低:主要依靠内核升级来获得新功能

LVS由于是基于四层的转发所以只能做端口的转发,而基于URL的、基于目录的这种转发LVS就做不了


Nginx

  • 工作在第7层,应用层,可以针对http应用做一些分流的策略。比如针对域名、目录结构。它的正则比HAProxy更为强大和灵活;

  • Nginx对网络的依赖非常小,理论上能ping通就就能进行负载功能

  • Nginx安装和配置简单

  • 可以承担高的负载压力且稳定,一般能支撑超过几万次的并发量;

  • Nginx不仅仅是一款优秀的负载均衡器/反向代理软件,它同时也是功能强大的Web应用服务器。Nginx在处理静态页面、特别是抗高并发方面相对apache有优势;

  • Nginx作为Web反向代理加速缓存越来越成熟,速度比传统的Squid服务器更快

  • Nginx处理请求的方法:请求和响应数据都会经过 Nginx。

    Nginx采用的是异步转发。可以做到:如果一个服务器请求失败,立即切换到其他服务器,直到请求成功或者最后一台服务器失败为止。可以最大程度的提高系统的请求成功率。异步转发:Nginx 在保持客户端连接的同时,发起一个相同内容的新请求到后端,等后端返回结果后,由 Nginx 返回给客户端。


HAProxy

  • HAProxy是支持虚拟主机的,可以工作在4、7层(支持多网段);
  • 能够补充Nginx的一些缺点比如Session的保持,Cookie的引导等工作;
  • 支持url检测后端的服务器;
  • 它跟LVS一样,本身仅仅就只是一款负载均衡软件;单纯从效率上来讲HAProxy更会比Nginx有更出色的负载均衡速度,在并发处理上也是优于Nginx的;
  • HAProxy可以对Mysql读进行负载均衡,对后端的MySQL节点进行检测和负载均衡,不过在后端的MySQL slaves数量超过10台时性能不如LVS;
  • HAProxy的算法较多,达到8种;

总结

  • HAproxy和Nginx由于可以做七层的转发,所以URL和目录的转发都可以做。
  • 在很大并发量的时候我们就要选择LVS,像中小型公司的话并发量没那么大,选择HAproxy或者Nginx足已,由于HAproxy由是专业的代理服务器配置简单,所以中小型企业推荐使用HAproxy

参考

https://www.cnblogs.com/jojoword/p/10835102.html
https://cloud.tencent.com/developer/article/2107913


http://www.ppmy.cn/news/1509098.html

相关文章

记录|C#主界面设计【Web风格】

目录 前言一、页面效果二、布局设计2.1 左边菜单栏搭建框架Step1. panelMenu :Step2. panelLogoStep3. button模板Step4. 复制buttonStep5. 微调Button 2.2 界面颜色变换Step1. ThemeColor类Step2. From1.csStep3. 更换按钮点击颜色效果 2.3 按钮点击事件2.4 顶部ti…

Unity 编写自己的aar库,接收Android广播(broadcastReceiver)并传递到Unity

编写本文是因为找了很多文章,都比较片段,不容易理解,对于Android新手来说理解起来不友好。我这里写了一个针对比较小白的文章,希望有所帮助。 Android端 首先还是先来写Android端,我们新建一个Android空项目&#xf…

spring data:核心概念与应用(1)

文章目录 核心概念定义Repository接口Repository 微调 投影 使用过 JPA 的同学比较了解在 Spring 体系的 web 服务开发中,有个比较方便的 dao 工具 repository,并伴随着 Entity 形成的一系列方法能大大加快开发进程,本系列就以 Spring Data 系…

MTF-SFR总结/探讨

空间频率响应(SFR)定义 在iso12233:2000中,空间频率响应(SFR)测量被定义为通过分析倾斜黑白边缘附近的相机数据而测量的值。 图像清晰度测试方法 通过ISO12233测试图像清晰度的方法,一般有 TVline测试和S…

basic_pentesting_2靶机

靶机地址:Basic Pentesting: 2 ~ VulnHub 攻击机kali和靶机要设在同一网段,查看靶机MAC地址: 一、信息收集 扫描目标主机 arp-scan -l 使用nmap扫描靶机开放的端口: nmap -A -sS -sV -v -p- 192.168.7.127 浏览器访问80端口&a…

git-贮藏区打补丁

1.显示所有贮藏 git stash list 2.将贮藏区的修改打补丁 git stash show -p stash{0} > patchName.patch commit打补丁 git 生成补丁文件及打补丁_git 生成指定目录补丁-CSDN博客 git patch的使用方法_git pattch-CSDN博客

STM32低功耗与备用备份区域

STM的备份备用区域其实就是两个区块:BKP和RTC。低功耗则其实是STM32四种模式中的三种耗能很低的模式。 目录 一:备用区域 1.BKP 2.RTC 二:低功耗模式 1.睡眠模式: 2.停机模式: 3.待机模式: 一&…

oracle 保留两位小数

在Oracle数据库中,保留两位小数可以通过多种函数实现,主要包括ROUND、TRUNC和TO_CHAR函数。每种函数都有其特定的使用场景和效果。 1. ROUND函数 ROUND函数用于对数值进行四舍五入操作,保留指定的小数位数。其基本语法为: ROUN…