• Spring Cloud项目(四)——使用Ribbon作为负载均衡


    前期准备

    一个使用nacos作为注册中心的springcloud项目,

    项目结构

    在这里插入图片描述

    步骤

    1、新建模块springcloud-provider2,并复制原springcloud-provider模块的代码及依赖到该模块中
    2、修改启动类名称、UserService里的对象内容及yml里的服务端口
    3、按顺序启动:nacos、provider、provider2、consumer

    测试结果

    在这里插入图片描述
    浏览器访问localhost:8081/consumer/findById/2
    在这里插入图片描述
    刷新该页面:
    在这里插入图片描述

    经过测试发现,我们不断的在这两个对象之间进行切换,这是因为负载均衡在帮我们选择该使用哪一个provider。

    什么是负载均衡

    负载均衡是高可用网络基础架构的关键组件,通常用于将工作负载分布到多个服务器来提高网站、应用、数据库或其他服务的性能和可靠性。

    一个没有负载均衡的 web 架构类似下面这样:
    在这里插入图片描述

    在这里用户是直连到 web服务器,如果这个服务器宕机了,那么用户自然也就没办法访问了。另外,如果同时有很多用户试图访问服务器,超过了其能处理的极限,就会出现加载速度缓慢或根本无法连接的情况。

    而通过在后端引入一个负载均衡器和至少一个额外的 web 服务器,可以缓解这个故障。通常情况下,所有的后端服务器会保证提供相同的内容,以便用户无论哪个服务器响应,都能收到一致的内容。

    在这里插入图片描述
    常见的负载均衡方式有两种:

    • 服务端负载均衡
    • 客户端负载均衡

    服务端负载均衡
    在这里插入图片描述
    服务端负载均衡具有以下特点:

    • 需要建立一个独立的负载均衡服务器。
    • 负载均衡是在客户端发送请求后进行的,因此客户端并不知道到底是哪个服务端提供的服务。
    • 可用服务端清单存储在负载均衡服务器上。

    客户端负载均衡
    在这里插入图片描述
    客户端负载均衡具有以下特点:

    • 负载均衡器位于客户端,不需要单独搭建一个负载均衡服务器
    • 负载均衡是在客户端发送请求前进行的,因此客户端清楚地知道是哪个服务端提供的服务。
    • 客户端都维护了一份可用服务清单,而这份清单都是从服务注册中心获取的。

    既然如此,我之前又在哪里使用了负载均衡吗?
    在这里插入图片描述
    其实,LoadBalancerClient就是使用的Ribbon作为负载均衡

    什么是Ribbon

    Spring Cloud Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,它基于Netflix Ribbon实现。通过Spring Cloud的封装,可以让我们轻松地将面向服务的REST模版请求自动转换成客户端负载均衡的服务调用。Spring Cloud Ribbon虽然只是一个工具类框架,它不像服务注册中心、配置中心、API网关那样需要独立部署,但是它几乎存在于每一个Spring Cloud构建的微服务和基础设施中。因为微服务间的调用,API网关的请求转发等内容,实际上都是通过Ribbon来实现的

    Ribbon的负载均衡策略

    不断跟踪代码,发现IRule接口就是用来实现负载均衡策略的
    在这里插入图片描述

    • RandomRule:随机策略,就是从服务器中随机选择一个服务器,
    • RoundRobinRule:轮询策略,表示每次都取下一个服务器。比如一共有5台服务器,第1次取第1台,第2次取第2台,第3次取第3台,以此类推。也是ribbon的默认策略
    • WeightedResponseTimeRule:继承了RoundRobinRule,开始的时候还没有权重列表,采用父类的轮询方式,有一个默认每30秒更新一次权重列表的定时任务,该定时任务会根据实例的响应时间来更新权重列表,choose方法做的事情就是,用一个(0,1)的随机double数乘以最大的权重得到randomWeight,然后遍历权重列表,找出第一个比randomWeight大的实例下标,然后返回该实例
    • BestAvailableRule策略用来选取最少并发量请求的服务器

    自定义使用其他策略

    修改之前consumer的config类

    package com.lx.config;
    
    import com.netflix.loadbalancer.IRule;
    import com.netflix.loadbalancer.RandomRule;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.client.RestTemplate;
    
    @Configuration
    public class RestTemplateConfig {
    
        @Bean
        public RestTemplate getRestTemplate(){
            return new RestTemplate();
        }
        
        /**
         * 设置负载均衡的策略
         */ 
        @Bean
        public IRule rule(){
            return new RandomRule();
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    扩展

    服务端负载均衡与客户端负载均衡对比:
    在这里插入图片描述

    附:参考资料

    1、什么是负载均衡?
    2、Ribbon:Spring Cloud负载均衡与服务调用组件(非常详细)
    3、Ribbon详解
    4、Ribbon的负载均衡策略及原理

    结语

    下面关于Spring Cloud学习系列的博客的连接有的是不能使用的,因为博主还在努力创作中,敬请期待

    附:Spring Cloud学习系列

    Spring Cloud项目(一)——集成Nacos作为注册中心
    Spring Cloud项目(二)——集成Nacos作为配置中心
    Spring Cloud项目(三)——实现Nacos数据信息持久化到MySQL
    Spring Cloud项目(四)——使用Ribbon作为负载均衡
    Spring Cloud项目(五)——使用openFeign作为服务调用
    Spring Cloud项目(六)——使用sentinel作为流量管理
    Spring Cloud项目(七)——使用sentinel作为限流和熔断
    Spring Cloud项目(八)——使用gateway作为服务网关

  • 相关阅读:
    easyexcel同步下载简单使用
    ELK入门(二)- springboot整合ES
    WPF几何绘图(2)
    C++性能分析工具gperftools安装教程与使用案例分析
    分享 2022 年最受欢迎的黑科技工具(二)
    在什么情况下要向美国专利商标局申请临时专利?
    探究——C# .net 代码混淆/加壳
    【附源码】计算机毕业设计JAVA超市货品进销存系统前台
    全波形反演培训的思考与总结
    Hugging Face 分词器新增聊天模板属性
  • 原文地址:https://blog.csdn.net/weixin_45974176/article/details/126418239