SpringCloud(五):Ribbon负载均衡服务调用

news/2024/7/10 1:19:17 标签: spring cloud, ribbon, 负载均衡

文章目录

5. Ribbon负载均衡服务调用

概述

在这里插入图片描述

Ribbon负载均衡演示

  1. 架构

    总结:Ribbon其实就是一个软负载均衡的客户端组件,他可以和其他所需请求的客户端结合使用,和eureka结合只是其中的一个实例。
    在这里插入图片描述

  2. POM

在这里插入图片描述

  1. 二说RestTemplate的使用:负载均衡+RestTemplate调用

    • getForObject方法/getForEntity方法

    • postForObject/postForEntity

Ribbon核心组件IRule

在这里插入图片描述

  • IRule:根据特定算法从服务列表中选取一个要访问的服务

    • com.netflix.loadbalancer.RoundRobinRule:轮询
    • com.netflix.loadbalancer.RandomRule:随机
    • com.netflix.loadbalancer.RetryRule:先按照RoundRobinRule的策略获取服务,如果获取服务失败则在指定时间内会进行重试
    • WeightedResponseTimeRule :对RoundRobinRule的扩展,响应速度越快的实例选择权重越大,越容易被选择
    • BestAvailableRule :会先过滤掉由于多次访问故障而处于断路器跳闸状态的服务,然后选择一个并发量最小的服务
    • AvailabilityFilteringRule :先过滤掉故障实例,再选择并发较小的实例
    • ZoneAvoidanceRule:默认规则,复合判断server所在区域的性能和server的可用性选择服务器
  • 替换

    • 修改cloud-consumer-order80

    • 注意配置细节

    • 新建package:com.atguigu.myrule

    • 上面包下新建MySelfRule规则类

      package com.atguigu.myrule;
      
      import com.netflix.loadbalancer.IRule;
      import com.netflix.loadbalancer.RandomRule;
      import org.springframework.context.annotation.Bean;
      import org.springframework.context.annotation.Configuration;
      
      @Configuration
      public class MySelfRule {
      
          @Bean
          public IRule myRule(){
              return new RandomRule();//定义为随机
          }
      }
      
    • 主启动类添加@RibbonClient

      @EnableEurekaClient
      @SpringBootApplication
      @RibbonClient(name = "CLOUD-PAYMENT-SERVICE",configuration = MySelfRule.class)
      public class OrderMain80 {
          public static void main(String[] args) {
              SpringApplication.run(OrderMain80.class,args);
          }
      }
       
      
    • 测试

Ribbon负载均衡算法

  1. 原理

在这里插入图片描述

  1. RoundRobinRule源码

http://www.niftyadmin.cn/n/1016102.html

相关文章

SpringCloud(六):OpenFeign服务接口调用

文章目录概述OpenFeign使用步骤OpenFeign超时控制OpenFeign日志打印功能概述 OpenFeign使用步骤 接口注解&#xff1a;微服务调用接口FeignClient 新建cloud-consumer-feign-order80 POM <dependency><groupId>org.springframework.cloud</groupId><art…

没有ggplot这个函数_这个lncRNA机制图是用PPT画的!

欢迎分享本文到朋友圈&#xff0c;文章转载、投稿、业务合作联系请微信Havana90~~在分子生物学的一些综述里&#xff0c;漂亮的插图是能够为文章加分的。像下图表示lncRNA的几种作用机制(不知道哪篇文章的&#xff0c;我用PPT仿的)&#xff0c;这样的图能够让读者直观明了地获得…

SpringBoot(一):配置

文章目录1. 配置1.1 SpringBoot特点1.1.1 依赖管理1.1.2 自动配置1.2 容器功能1.2.1 组件添加ConfigurationBean、Component、Controller、Service、RepositoryComponentScan、ImportConditional1.2.2 原生配置文件引入ImportResource1.2.3 配置绑定ConfigurationProperties C…

可以两个人协作一个项目吗_一个人也可以创业的餐饮好项目...

从原本路边几毛一元不起眼到现在各大品牌&#xff0c;升价翻倍&#xff0c;甚至有和正餐相同市场地位的小吃&#xff0c;不得不说&#xff0c;它赢了&#xff0c;人人都爱吃小吃&#xff0c;都离不开小吃&#xff0c;小吃创业开店也成了新的潮流趋势&#xff0c;这些都有数据证…

android bitmap 获取像素点 太慢_广色域照片闪亮登场 Android: 开发者需知两三事

作者: Lin Peiyong, 软件工程师Android 现已迎来新一轮的图像革新&#xff0c;由于 sRGB 的每个色彩通道只有 8 个比特&#xff0c;因此标准 sRGB 色域无法充分体现屏幕与摄像头最新技术的优势所在。Android 一直在努力实现对广色域图像的端到端支持&#xff0c;例如&#xff0…

基于BIO模式下通信项目

文章目录功能清单代码结构服务端设计接收多个客户端逻辑接收登陆消息及监测离线接收群聊消息接收私聊消息代码实现客户端设计启动客户端界面&#xff0c;登录&#xff0c;刷新在线客户端发送消息逻辑代码实现功能清单 1.客户端登陆功能 可以启动客户端进行登录&#xff0c;客…

iphone快捷指令蚂蚁森林能量_函数实践拓展——支付宝蚂蚁森林能量计算

蚂蚁森林是支付宝设计的一款公益活动&#xff0c;在支付宝完成低碳行为&#xff0c;如步行、线下支付、网络购票、公交等方式&#xff0c;就可以获得能量。利用所获得的能量在支付宝里养一棵虚拟的树&#xff0c;这棵树长大后&#xff0c;公益组织、环保企业等蚂蚁生态合作伙伴…

基于NIO模式下通信项目

功能清单 编写一个 NIO 群聊系统&#xff0c;实现客户端与客户端的通信需求&#xff08;非阻塞&#xff09;服务器端&#xff1a;可以监测用户上线&#xff0c;离线&#xff0c;并实现消息转发功能客户端&#xff1a;通过 channel 可以无阻塞发送消息给其它所有客户端用户&…