LVS,Nginx,Haproxy三种负载均衡产品的对比[通俗易懂]

LVS,Nginx,Haproxy三种负载均衡产品的对比[通俗易懂]本文介绍LVS,Nginx,Haproxy这三种负载均衡产品的区别。

大家好,又见面了,我是你们的朋友全栈君。

原文网址:LVS,Nginx,Haproxy三种负载均衡产品的对比_IT利刃出鞘的博客-CSDN博客

简介

        本文介绍LVS,Nginx,Haproxy这三种负载均衡产品的区别。

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

使用场景

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

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

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

LVS和Nginx结合使用的场景

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

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

LVS处理请求的方法:请求数据经过 LVS网络,响应数据由后端服务器的网络返回。

        LVS:采用的是同步转发。同步转发:LVS 服务器接收到请求之后,立即 redirect 到一个后端服务器,由客户端直接和后端服务器建立连接。

总结

        若仅使用Nginx:后端的服务器规模庞大时,Nginx 的网络带宽就成了一个巨大的瓶颈。

        若仅使用LVS:一旦后端接受到请求的服务器出了问题,那么这次请求就失败了。

        如果在 LVS 的后端在添加一层 Nginx(多个),每个 nginx 后端再有几台应用服务器,就可以结合两者的优势,既能避免单 Nginx 的流量集中瓶颈,又能避免单 LVS 在请求失败时无法切换服务器的问题。

详细对比

Nginx

LVS

所在网络层级

四层/七层

四层

抗负载能力

功能

功能多

能够根据域名、url的不同,将http请求分到不同的后端服务器。

节省带宽:支持gzip压缩,可以添加浏览器本地缓存的header头。

功能少

同时也减少了人为出错的概率

稳定性

稳定性低,有单机故障

无现成的双机热备方案

稳定性高

有完整的双机热备方案

网络架构依赖

无依赖。

强依赖

很依赖网络架构设计(可以采用简单的NAT方式解决此问题)

是否会重试

不重试

数据包分发到坏的后端并返回错误后,会尝试重新分发到健康的后端

会重试

数据包分发到坏的后端,不会重新分发,会直接返回错误

数据出入

所有的请求和响应流量都会经过Nginx

仅请求流量经过LVS的网络,响应流量由后端服务器的网络返回。

FULL_NAT同Nginx。

宿主机性能要求

要求较高

Nginx对源端和目的端都单独建立连接,中间涉及数据包的解析,所以依赖宿主机的I/O性能和CPU内存.

要求较低

LVS仅分发请求,流量并不从它本身出去,所以瓶颈仅仅受限于网络带宽和网卡性能

转发方式

异步转发

在保持客户端连接的同时,发起一个相同内容的新请求到后端,等后端返回结果后,由Nginx返回给客户端

同步转发

LVS服务器接收到请求之后,立即redirect到一个后端服务器,由客户端直接和后端服务器建立连接。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163768.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • AlertDialog的六种创建方式

    AlertDialog的六种创建方式AlertDialog 的六种创建方式 nbsp AlertDialog 的六种创建方式创建 AlertDialog 的步骤 1 创建 AlertDialog Builder 对象 2 调用 Builder 对象的 setTitle 方法设置标题 setIcon 方法设置图标 3 调用 Builder 相关方法如 setMessage 方法 setItems 方法 setSingleCho 方法 setMultiCh

    2025年6月7日
    3
  • 区块链名词解释_区块链公司起什么名字好

    区块链名词解释_区块链公司起什么名字好区块链名词解释

  • windows11修改用户名_win10家庭中文版怎么更改用户名

    windows11修改用户名_win10家庭中文版怎么更改用户名按:新买的电脑一般预装Windows11系统(家庭与学生版),新电脑初次开机使用微软邮箱账号登录,则系统将用户名自动设置成邮箱前几位。我的用户名便是一串数字【231xx】(qq邮箱前5位),看着很不舒服,查了很多方法并最终修改成功!!记录一下修改过程,希望能帮到同样想改用户名的人。首先,强调一点,修改失败可能导致很严重的问题,电脑如有重要资料,务必请提前备份!!!一什么情况需要修改用户名最主要的情况就是初次使用设置了中文用户名。很多软件不支持路径包含中文字……………..

    2022年10月14日
    1
  • python字符串模糊匹配_python匹配字符

    python字符串模糊匹配_python匹配字符广告关闭提供包括云服务器,云数据库在内的50+款云计算产品。打造一站式的云产品试用服务,助力开发者和企业零门槛上云。假设我有一个名为file1.txt的下面的文本文件:adammalejohnmalemikemalesuefemale我有下面的清单fullname=我希望能够通过文本文件,如果它有任何匹配,修改带有找到的单词的行,输出应如下所示:adammalejohnmalef…

    2022年7月25日
    15
  • ant 编译java(java是干啥的)

    1.什么是antant是构建工具2.什么是构建概念到处可查到,形象来说,你要把代码从某个地方拿来,编译,再拷贝到某个地方去等等操作,当然不仅与此,但是主要用来干这个3.ant的好处跨平台–因为ant是使用java实现的,所以它跨平台使用简单–与ant的兄弟make比起来语法清晰–同样是和make相比功能强大–ant能做的事情很多,可能你用了很久,你仍然不知道它能有多少功能。当你自己开发…

    2022年4月11日
    51
  • 一个好玩的小游戏(纯C语言编写)

    一个好玩的小游戏(纯C语言编写)最近在看知乎是发现了一个这一个专栏https://zhuanlan.zhihu.com/c2game从中获取的许多知识,本文中的游戏也是从里面学到的,不过本人又自己加了一些功能。这是一个类似于飞机大战的游戏,不过目前代码量比较小,所以看起来非常简陋游戏界面如下更新日志,本人将原来的原来的代码有进一步的优化了一下,之前是只有一个非常小的战机现在更新后可以产生一个非常大的战机(看起来也更

    2022年5月19日
    44

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号