使用 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 实现客户端侧负载均衡的主要内容,如果未能解决你的问题,请参考以下文章

使用Ribbon实现客户端侧负载均衡

springCloud:Ribbon实现客户端侧负载均衡-消费者整合Ribbon

2.Spring Cloud Alibaba实现负载均衡-Ribbon

0403-Ribbon的基本使用

ribbon源码之概述

springcloud-04-自定义ribbon的配置方式