码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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作为服务网关

  • 相关阅读:
    Reflect 对象的创建目的
    【kotlin】利用by关键字更加方便地实现装饰器模式
    经典网络学习-ResNet代码实现
    漫谈:编码、哈希、摘要、加密都是什么(别再问“用base64加密行不行”了,会被鄙视)
    【面试经典150 | 区间】插入区间
    system V共享内存
    Angular+html+js前端加载生命周期
    android安全基础知识学习
    面试还被问TCP?一条龙通关
    【负荷预测】基于双向LSTM模型进行电力需求预测(Matlab代码实现)
  • 原文地址:https://blog.csdn.net/weixin_45974176/article/details/126418239
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号