负载均衡可以简单分为服务端负载均衡和客户端负载均衡这两种。 根据 OSI 模型,服务端负载均衡还可以分为:
最常见的是四层和七层负载均衡
七层负载均衡比四层负载均衡会消耗更多的性能,不过,也相对更加灵活,能够更加智能地路由网络请求,比如说你可以根据请求的内容进行优化如缓存、压缩、加密。 简单来说,四层负载均衡性能更强,七层负载均衡功能更强! 常用的七层负载均衡解决方案:DNS 解析和反向代理 在工作中,我们通常会使用 Nginx 来做七层负载均衡,LVS(Linux Virtual Server 虚拟服务器, Linux 内核的 4 层负载均衡)来做四层负载均衡。
一、服务端负载均衡服务端负载均衡 主要应用在系统外部请求和网关层之间,可以使用软件或 硬件实现。 在我们日常开发中,一般很难接触到硬件负载均衡,接触的比较多的还是软件负载均衡 。软件负载均衡通过软件(比如 LVS、Nginx、HAproxy )实现负载均衡功能。 二、客户端负载均衡客户端负载均衡主要应用于系统内部的不同服务之间,可以使用现成的负载均衡组件来实现。 在客户端负载均衡中,客户端会自己维护一份服务器的地址列表,发送请求之前,客户端会根据对应的负载均衡算法来选择具体某一台服务器处理请求。 客户端负载均衡器和服务运行在同一个进程或者说 Java 程序里,不存在额外的网络开销。不过,客户端负载均衡的实现会受到编程语言的限制,比如说 Spring Cloud Load Balancer 就只能用于 Java 语言。 Java 领域主流的微服务框架 Dubbo、Spring Cloud 等都内置了开箱即用的客户端负载均衡实现。Dubbo 属于是默认自带了负载均衡功能,Spring Cloud 是通过组件的形式实现的负载均衡,属于可选项,比较常用的是 Spring Cloud Load Balancer(官方,推荐) 和 Ribbon(Netflix,已被启用)。 Ribbon 支持的 7 种负载均衡策略:
Spring Cloud Load Balancer 支持的 2 种负载均衡策略:
不过,Spring Cloud Load Balancer 支持的负载均衡策略其实不止这两种,看官方文档。
三、负载均衡常见的算法随机法轮询法一致性 Hash 法最小连接法四、Nginx负载均衡实现原理 Nginx服务器作为前端,Tomcat服务器作为后端,页面请求由Nginx服务来进行转发请求到不同的web服务器上,但是不是把所有的Web请求转发,静态页面请求Nginx服务器自己来处理,动态页面请求转发给后端的Tomcat服务器来处理。 五、Nginx和Ribbon的区别 Nginx是服务端负载均衡,客户端所有请求都会交给nginx,然后由nginx实现转发请求到不同的web服务器上(如Tomcat),即负载均衡是由服务端实现的。 Nginx是一个独立运行的服务器,通过反向代理实现负载均衡。Ribbon是一个客户端负载均衡组件,它依赖于服务注册中心给出的服务列表,做服务路由选择。两个定位不一样,工作模式和位置也不一样。在某些基于DNS负载场合,两者是可以结合起来使用的。 其实如果用k8s的话,甚至springcloud都不需要,看项目和团队怎么抉择吧。 六、正向代理和反向代理的区别
vpn是在用户浏览器端设置的(并不是在远端的服务器设置)。 反向代理: 反向代理是作用在服务器端的,是一个虚拟ip(VIP)。对于用户的一个请求,会转发到多个后端处理器中的一台来处理该具体请求。 注意:无论是正向代理和反向代理,实际上相互都不知道对方,他们只需要明确自己的需求和结果,而中间的发送和返回的过程并不关心,实际上一个传输的过程中完全有可能存在正向代理和反向代理两种模式,当你使用vpn(正向)访问一个使用了负载均衡(反向)的服务器。 例子:
|
原文地址:https://blog.csdn.net/mrxutada/article/details/131685002
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:https://www.msipo.com/article-1031.html 如若内容造成侵权/违法违规/事实不符,请联系MSIPO邮箱:3448751423@qq.com进行投诉反馈,一经查实,立即删除!
Copyright © 2024, msipo.com