使用 Ribbon 实现客户端侧负载均衡
Posted zolmk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用 Ribbon 实现客户端侧负载均衡相关的知识,希望对你有一定的参考价值。
使用 Ribbon 实现客户端侧负载均衡
一、基本用法
一般如果导入 Eureka Client 服务的话,自动包含了 Ribbon,所以无需再次导入。
用法如下:
第一种:创建一个名为 RestTemplate 的 bean,并为其添加 @LoadBalanced 注解,使用该 RestTemplate 请求其他服务的接口即可实现客户端侧负载均衡,当 Eureka 和 Ribbon 联合使用时可使用虚拟域名直接访问微服务,如 restTemplate.getForObject("http://user-info-server/sys/info",User.class)
。
第二种:自动写入一个 LoadBalancerClient 类实例,使用该实例的 choose 方法可以选择微服务,然后可以查看该微服务的一些信息。
@Autowired private LoadBalancerClient loadBalancerClient;
ServiceInstance serviceInstance = this.loadBalancerClient.choose("user-info-server");
//使用 ServiceInstance 可以获取微服务的 Host、Port
二、自定义 Ribbon 配置
Java 代码配置
1、创建 Ribbon 配置类
/**
* 注意:该类不应该在主程序上下文的 @ComponentScan 中
**/
@Configuration
public class RibbonConfiguration
{
@Bean
public IRule ribbonRule()
{
return new RandomRule();
}
}
2、创建一个空类,并在其上添加 @Configuration 和 @RibbonClient 注解。
/**
* 使用 RibbonClient,为特定 name 的 Ribbon Client 自定义配置。
* 使用 @RibbonClient 的 configuration 属性,指定 Ribbon 的配置类
**/
@Configuration
@RibbonClient(name = "user-info-server",configuration = RibbonConfiguration.class)
public class RibbonClientConfigration
{}
以上是关于使用 Ribbon 实现客户端侧负载均衡的主要内容,如果未能解决你的问题,请参考以下文章
springCloud:Ribbon实现客户端侧负载均衡-消费者整合Ribbon