LVS四层 VS Nginx七层反代(负载均衡)

时间:2023-01-22 05:51:59

1、场景:

最近不少朋友聊天谈到面试总是问到LVS四层反代和Nginx七层反代,有点不知所措。

负载均衡可以将用户的请求分发到 web集群的某台机器,反向代理也是实现了这个功能。如果后端是一台服务器就叫反向代理,如果有多台就是负载均衡。反向代理才能实现负载均衡 负载均衡是做反向代理的目的之一。

2、博主则探讨一下四层反代和的七层反代的区别(三层负载均衡不探讨),如有不足,请指出。

负载均衡(Load Balance)

也称四层、七层交换机

四层负载均衡

七层负载均衡

(通常七层支持四层)

技术原理

ip+tcp(端口)

URL应用层(也称内容交换)

典型代表

LVS、F5等

Nginx、Haproxy,MySQL Proxy等

 

 

 

缺点和优点

不理解MySQL,ftp,http等应用协议等,满足不了特定的需求,比如动静分离,缓存自定义等但是配置简单,效率也很高。

对负载均衡设备要求很高,处理七层能力一般低于四层模式的部署方式,但有点比较智能化,比如动静分离,根据不同请求定义图片,缓存,可以对客户端请求和服务器的相应进行自定义修改,极大提升了应用系统在网络层的灵活性

安全性

eg:SYNFlood攻击,有的软四层应用则会转发到后端服务器,有的则可以防止攻击,这个和设备(软硬)有一定关系。

一般可以在七层进行拦截,不影响后台服务器正常运营,可以设置多种策略,过滤特定报文。

应用

对应tcp应用 比如C/S开发的ERP

应用广发HTTP协议,应用主要是网站或内部信息平台等B/S开发的系统。


案例(工作原理)

接受客户的syn请求,通过上述方式选择后端指定服务器,并对报文中目标ip地址进行修改,改为后端服务器ip,tcp连接是直接建立,而负载均衡类似路由器作用

如果要根据真正的应用层内容在选择服务器,则先代理最终服务器和客户端建立连接(三次握手)后,才可能接受到客户端发送的真正应用层内容报文,然后根据该报文中特定字段,加上负载均衡设备的服务器选择方式,决定最终选择的内部服务器。此时充当了代理服务器。


四层七层选择

1、  根据需求使用,七层可以提高流量智能化,但配置复杂化

2、  追求安全性,或者性能

3、  考虑灵活性和扩展性

3、问到LVS四层、七层反代(负载均衡),则可以通过上面几个方式谈:

3.1)技术原理

3.2)优缺点

3.3)安全性

3.4)应用场景

3.5)工作原理

3.6)四层七层的选择

本文出自 “永不放弃!任志远” 博客,转载请与作者联系!