SpringCloud之Ribbon

1 Ribbon的作用

Robbin可以帮助我们实现客户端负载均衡,在服务调用方在发送请求到其他服务时,在本地通过你指定负责均衡策略,筛选指定的服务调用。

2 Ribbon入门

2.1在服务的调用方导入依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>

2.2 在RestTemplate配置上添加注解

@Bean
@LoadBalanced
public RestTemplate restTemplate(){
	return new RestTemplate();
}

2.3 使用restTemplate对象调用

restTemplate.getForObject("http://服务名称/路径", 返回结果.class);

Ps:在通过EurekaClient获取服务的地址信息,得到的时机器名称作为ip地址

# 指定服务展示的信息
eureka:
  instance:
    prefer-ip-address: true
    ip-address: localhost
    home-page-url: http://${eureka.instance.ip-address}:${server.port}

3 Ribbon指定负载均衡策略

Ribbon提供的负载均衡策略:

  • RoundRobinRule:轮询(默认)
  • RandomRule:随机策略
  • WeightedResponseTimeRule:权重,默认根据响应时间指定权重值
  • BestAvailableRule:根据并发,哪个服务并发少,就找哪个服务

配置负载均衡策略:
配置文件

服务名:
  ribbon:
    NFLoadBalancerRuleClassName: 负载均衡策略类的全路径

配置类

@Bean
public IRule ribbonRule(){
    return new RandomRule();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一个基于Spring Boot的开发工具集,提供了一系列用于构建分布式系统的解决方案。其中,Feign和Ribbon是Spring Cloud中常用的两个组件。 Feign是一个声明式的Web服务客户端,用于简化使用Spring Cloud的服务之间进行通信的过程。它通过支持注解方式来定义和使用服务接口,底层使用的是基于反射的动态代理技术,将接口和实际调用的服务进行映射。Feign通过集成Ribbon来实现负载均衡的功能。 Ribbon是一个负载均衡的组件,它根据一系列的负载均衡策略,从多个服务实例中选择一个要调用的实例。Ribbon通过监听Eureka注册中心上已注册的服务列表,并通过默认的轮询算法选择一个实例。在Feign中,Ribbon用于根据服务接口定义的URL和方法,选择一个具体的服务进行调用。 Feign和Ribbon的原理可以简单总结如下:首先,Feign通过使用@EnableFeignClients注解开启Feign功能,扫描包中带有@FeignClient注解的接口定义。接着,Feign将这些接口定义转化为动态代理对象,在调用接口方法时,实际上是通过动态代理对象进行了解析和转发,最终会调用到具体的服务实例上。此时,Ribbon会根据一定的策略从多个服务实例中选择一个实例进行调用,并返回调用结果。整个调用过程是通过HTTP协议进行通信的。 总之,Spring Cloud中的Feign和Ribbon组件能够实现微服务之间的通信和负载均衡功能。Feign简化了基于HTTP的服务接口定义和调用的过程,而Ribbon则负责根据一定的负载均衡策略选择合适的服务实例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值