关于LVS+Nginx为什么会被同时使用的思考

最初的理解

(也可以每个nginx都挂在上所有的应用服务器) 
nginx大家都在用,估计也很熟悉了,在做负载均衡时很好用,安装简单、配置简单、相关材料也特别多。

lvs是国内的章文嵩博士的大作,比nginx被广泛接受还要早7年,并且已经被红帽作为了系统内置软件,可谓很牛了。lvs相对于nginx来说配置上就要相对复杂一些。

但是,有时候我们会看到大牛们分享的经验里面是lvs+nginx作为负载均衡了,一直想不明白这是个什么道理。

为什么会出现两者被同时使用呢?其实,这要从两者的各自优势来说了。

nginx用来做http的反向代理,能够upsteam实现http请求的多种方式的均衡转发。由于采用的是异步转发可以做到如果一个服务器请求失败,立即切换到其他服务器,直到请求成功或者最后一台服务器失败为止。这可以最大程度的提高系统的请求成功率。

lvs采用的是同步请求转发的策略。这里说一下同步转发和异步转发的区别。同步转发是在lvs服务器接收到请求之后,立即redirect到一个后端服务器,由客户端直接和后端服务器建立连接。异步转发是nginx在保持客户端连接的同时,发起一个相同内容的新请求到后端,等后端返回结果后,由nginx返回给客户端。

进一步来说:当做为负载均衡服务器的nginx和lvs处理相同的请求时,所有的请求和响应流量都会经过nginx;但是使用lvs时,仅请求流量经过lvs的网络,响应流量由后端服务器的网络返回。

也就是,当作为后端的服务器规模庞大时,nginx的网络带宽就成了一个巨大的瓶颈。

但是仅仅使用lvs作为负载均衡的话,一旦后端接受到请求的服务器出了问题,那么这次请求就失败了。但是如果在lvs的后端在添加一层nginx(多个),每个nginx后端再有几台应用服务器,那么结合两者的优势,既能避免单nginx的流量集中瓶颈,又能避免单lvs时一锤子买卖的问题。

参考文章: 
章文嵩:LVS项目介绍 
moon:强大的nginx反向代理异步传输模式(原理) 

yaoweibin:nginx健康检查 
追马博客:LVS+keepalived+nginx+tomcat部署实现

补充(20160731 下午2:07):

在后续继续了解这部分内容时,发现了这两个帖子: 
1. 有了LVS,还要apache,nginx有什么用? 
2.从一个开发的角度看负载均衡和LVS—–注意看最后一个lvs集群化的图,nginx和rs是一对一连接的。

从以上文章来看,lvs+nginx组合使用的原因主要是用lvs来做负载均衡(因为工作在4层,效率高),nginx来做静态文件的处理。

这里第二篇文章,和lvs的后续维护者之一的[吴佳明_普空的ppt](http://velocity.oreilly.com.cn/2012/ppts/pukong.pdf 
)中比章博士的文章中多出了一种转发模式,也就是full_nat模式,这种模式下,所有的响应也要经过lvs服务器作为出口返回给客户端。

lvs在full_nat的模式下,是否还是同步的模式呢?我猜想应该是的,因为lvs工作在4层,所以可能当前出错的响应要映射到之前的那一次请求(因为没有解析http包),所以也就做不到把错误转发到其他的应用服务器上重新处理。

另外,这个补充是不是就完全的否定了昨天(也就是补充之前的那一大段)的内容呢?我觉得并没有。昨天的理解可能不是正规大型互联网在使用的模式(当然,这里我不能确定,因为我没有大型互联网的经验),但是理论应该是对的。

具体一点,lvs+nginx的组合nginx用来做静态文件的处理的场景下,如果一次请求失败了,那么久不能被重新处理了,当然你的nginx也可以后挂1个以上的应用服务器(这样的话nginx实质上也是起到了lvs均衡补充的效果)。另外就是,nginx不是单单的作为静态文件的处理,而是作为lvs的一个补充,互相弥补均衡上的不足。

那么你可能会说lvs在4层上处理的高效就不复存在了,确实是的,这点要承认,但是,我们提高了系统请求的成功率,两者需要各自去选择和权衡。

另外,需要说的一点是,静态内容其实我们还可以借助cdn去处理,而不是单单的依靠nginx或者apache去处理。

补充(2016年12月17日 上午11:24)

现在到了比较大一些的互联网公司,也看了京东的用法(可以看开涛的nginx+lua系列http://www.iteye.com/blogs/subjects/nginx-lua)。

lvs+nginx的使用中,nginx还可以作为一个中间环节来减小后端tomcat的服务压力,以及做一些业务切换、分流、前置缓存的功能。





http://blog.csdn.net/BuquTianya/article/details/52076153


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: b'lvs+keepalived+nginx' 是一种常用的负载均衡解决方案,其中 lvs( Linux Virtual Server) 作为负载均衡器,keepalived 作为高可用方案,nginx 作为 Web 服务器。它们结合起来可以实现高效、高可靠的负载均衡。 ### 回答2: LVS是Linux Virtual Server的缩写,它是一个开源的,基于Linux内核实现的高可用和可伸缩网络服务器集群系统。LVS在网络服务器中用于将大量的网络流量分配到多个后端服务器上,从而提高服务器的负载均衡和可伸缩性。LVS主要包括四个模块:IPVS,IPVSADM,KEEPALIVED和WEBUI。其中IPVS是实现流量分配的核心部分,IPVSADM可以监控和管理IPVS的规则,KEEPALIVED可用于实现高可用性,WEBUI可用于通过Web界面管理LVS集群。 KEEPALIVED是一款基于VRRP(Virtual Router Redundancy Protocol,虚拟路由器冗余协议)的高可用性解决方案。当主服务器发生故障时,KEEPALIVED自动将VIP(Virtual IP,虚拟IP)转移到备份服务器上,从而保证服务的不中断。KEEPALIVED可以与LVS集成使用,实现高可用的LVS集群。 Nginx是一款开源的高性能Web服务器和反向代理服务器。Nginx是一款非常流行的Web服务器,它可以提供高性能的Web服务,并支持负载均衡、反向代理、动态Web内容缓存等高级功能。在LVS集群中,Nginx通常被用作后端Web服务器,能够在LVS集群中进行负载均衡和高可用性配置,从而提高Web应用的可靠性和可伸缩性。 总的来说,LVS、KEEPALIVED和Nginx是三个非常实用的工具,它们可以在大型Web应用中实现高可用的负载均衡、高性能的Web服务器和反向代理服务器。这些工具能够提供更高的可靠性和可扩展性,从而满足企业在高流量和高负载的环境下的应用需求。 ### 回答3: LVS是Linux Virtual Server的缩写,是国产的高性能、高可用性的服务器集群技术。LVS可以分为四个子系统:IP负载均衡,服务调度,数据转发和应用服务器池。其中IP负载均衡是LVS的核心,通过对外提供虚拟IP地址和端口,将客户端的请求分发到不同的后端服务器上,实现负载均衡的目的。 Keepalived是一种高可用性的解决方案,它可以提供基于虚拟路由器热备的高可用性,并支持在主备节点间自动切换。Keepalived主要由两个组件组成:Keepalived daemon和VRRP脚本。Keepalived daemon通过VRRP协议实现主备节点的选举,VRRP脚本则用于检测服务器服务的可达性,并在必要时进行主备切换。 Nginx是一款高性能、轻量级的Web服务器和反向代理服务器,它在处理高并发连接和静态文件时表现出色,也可以作为负载均衡器使用Nginx支持通过upstream模块将请求转发到后端服务器,实现负载均衡的功能。 综合考虑,LVS和Keepalived可以协同工作实现高性能、高可用性的服务器集群。LVS将客户端请求分发到不同的应用服务器上,保证各个服务器的负载均衡;同时,Keepalived可以实现主备节点的选举和自动切换,保证服务的高可用性。Nginx作为反向代理服务器,可以挂载在LVS后面,接收LVS分发的请求,并将这些请求转发到后端服务器上,实现负载均衡的功能。通过这种方式,可以实现高性能、高可用性、可扩展性强、成本低的服务器集群。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值