当前位置: 首页 > news >正文

Springcloud笔记(4)-客户端负载均衡Ribbon

Ribbon是一个基于HTTP和TCP的客户端负载均衡工具,不需要独立部署,几乎存在于每一个springcloud构建的微服务和基础设施中。
微服务间调用,API网关的请求转发都通过Ribbon实现。

负载均衡

通常所说的负载均衡都是指的服务端负载均衡,包括硬件和软件,如软件的nginx。而ribbon是一个客户端负载均衡,客户端负载均衡中,所有客户端节点维护自己要访问的服务端清单,与服务注册中心配合完成。springcloud的服务治理框架,默认会整合ribbon,如Eureka。

在微服务架构中使用客户端负载均衡调用两步:
服务提供者只需要启动多个服务实例并注册到一个注册中心或是多个相关联的服务注册中心。
服务消费者直接通过调用被@LoadBalanced注解修饰过的RestTemplate来实现面服务的接口调用。

服务消费者的两个目标:发现服务和消费服务,发现服务由Eureka的客户端完成(通过@EnableDiscoveryClient注解让应用注册为Eureka客户端应用,获得服务发现能力),服务消费任务由ribbon完成(应用主类中创建RestTemplate的SpringBean实例,通过@LoadBalanced注解开启客户端负载均衡)

Eureka包含了ribbon,当ribbon与Eureka联合使用时,ribbon的服务实例清单会被扩展为从Eureka注册中心获取服务端列表。
还使用文章中的例子 Springcloud笔记(2)-Eureka服务注册中心-CSDN博客

服务消费 

 在 j-cloud-sonsumer的 HelloController.java代码

@RestController
public class HelloController {@Bean@LoadBalancedpublic RestTemplate getResttemplate(){return new RestTemplate();}@Autowiredprivate RestTemplate resttemplate;@RequestMapping("/hello")public String hello(){//指出服务地址   http://{服务提供者应用名名称}/{具体的controller}String url="http://provider-user/user/sayHello";//返回值类型和我们的业务返回值一致return resttemplate.getForObject(url, String.class);}}

 1、创建RestTemplate的Spring Bean实例,并通过@LoadBalanced注解开启客户端
负载均衡。

2、在接口实现中,调用RestTemplate创建的实例,使用getForObject方法实现对服务提供的/user/sayHello接口进行调用,可以看到这里的服务名为provider-user。

启动消费者访问查看控制台,Ribbon输出了当前客户端维护的provider-user的服务列表情况。其
中包含了各个实例的位置,Ribbo就是按照此信息进行轮询访问,以实现基于客户
端的负载均衡。另外还输出了一些其他非常有用的信息,如对各个实例的请求总数
量、第一次连接信息、上一次连接信息、总的请求失败数量等。

(使用ribbon来实现服务消费,ribbon对服务列表进行轮询,实现负载均衡)

RestTemplate

RestTemplate ,该对象会使用Ribbon的自动化配置,通过配置@LoadBanlanced开启客户端负载均衡。
在RestTemplate 中,对GET请求通过如下两个方法进行调用实现。
1)getForEntity
2) getForObject 
POST请求三个方法进行调用实现
1)postForEntity
2) postForObject
3) postForLocation

Ribbon支持的负载均衡策略

Ribbon内置了多种负载均衡策略,内部负载均衡的顶级接口为

com.netflix.loadbalancer.IRule

可以通过修改配置来调整Ribbon的负载均衡策略,具体代码如下

service-product: # 调用的提供者的名称

  ribbon:

    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule

http://www.lryc.cn/news/192472.html

相关文章:

  • MediaRecorder媒体录音机
  • 短视频如何批量添加水印
  • RT-Thread MQTT(学习)
  • Vue_Bug VUE-ELEMENT-ADMIN默认是英文模式
  • Spark中的Driver、Executor、Stage、TaskSet、DAGScheduler等介绍
  • docker的资源限制参数设置错误,导致的clickhouse性能瓶颈
  • Vue路由守卫有哪些,怎么设置,有哪些使用场景?
  • 云原生网关可观测性综合实践
  • vue-element-admin—登录页面添加自定义背景
  • 软设上午题-错题知识点一
  • 微信小程序(小程序入门)
  • 虹科分享 | 想买车无忧?AR为您带来全新体验!
  • easyUI重新渲染
  • html和css基础练习
  • Linux信号 signal()编程
  • 【LeetCode】16.最接近的三数之和
  • 嵌入式开发学习之STM32F407点亮LED及J-Link下载(二)
  • 智能呼叫中心系统的未来发展趋势:为企业开启全新服务模式
  • UE5中实现沿样条线创建网格体2-SplineMesh版本
  • 实现Element Select选择器滚动加载
  • C++ 之 Vector 和 List
  • 力扣-448.找到所有数组中消失的数字
  • 常用gdb调试命令
  • 【动手学深度学习-Pytorch版】BERT预测系列——用于预测的BERT数据集
  • 【数据结构-字符串 三】【栈的应用】字符串解码
  • Stm32_标准库_10_TIM_显示时间日期
  • 10-SRCNN-使用CNN实现超分辨成像
  • cmd/bat 输出符,控制台日志输出到文件
  • ODrive移植keil(七)—— 插值算法和偏置校准
  • 【肌电信号】OpenSignals使用方法 --- 肌电信号采集及导入matlab