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)四层七层的选择
本文出自 “永不放弃!任志远” 博客,转载请与作者联系!