使用Java代码自定义Ribbon配置

一 介绍
很多场景下,可能根据需要自定义Ribbon的配置,例如修改Ribbon的负载均衡规则等。Spring Cloud允许使用Java代码自定义Ribbon的配置。
在Spring Cloud中,Ribbon的默认配置如下(格式是BeanType beanName:ClassName)
IClientConfig ribbonClientConfig:DefaultClientConfigImpl
IRule ribbonRule:ZoneAvoidanceRule
IPing ribbonPing:NoOpPing
ServerList<Server> ribbonServerList:ConfigurationBasedServerList
ServerListFilter<Server> ribbonServerListFilter:ZonePreferenceServerListFilter
ILoadBalancer ribbonLoadBalancer:ZoneAwareLoadBalancer
ServerListUpdater ribbonServerListUpdater:PollingServerListUpdater
二 新建微服务microservice-consumer-movie-ribbon-customizing
三 创建Ribbon配置类
package com.itmuch.cloud.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RandomRule;

/**
* 该类为Ribbon的配置类
* 注意:该类不应该在主应用程序上下文的@ComponentScan 中。
*/
@Configuration
public class RibbonConfiguration {
  @Bean
  public IRule ribbonRule() {
    // 负载均衡规则,改为随机
    return new RandomRule();
  }
}
四 创建一个空类,并在其上添加相关注解
package com.itmuch.cloud.study.config;

import org.springframework.cloud.netflix.ribbon.RibbonClient;
import org.springframework.context.annotation.Configuration;

import com.itmuch.cloud.config.RibbonConfiguration;

/**
* 使用RibbonClient,为特定name的Ribbon Client自定义配置.
* 使用@RibbonClient的configuration属性,指定Ribbon的配置类.
* 可参考的示例:
* http://spring.io/guides/gs/client-side-load-balancing/
* @author 周立
*/
@Configuration
@RibbonClient(name = "microservice-provider-user", configuration = RibbonConfiguration.class)
public class TestConfiguration {
}
五 测试
1 启动eureka
2 启动两个user微服务
3 启动microservice-consumer-movie-ribbon-customizing微服务
测试结果是随机访问

猜你喜欢

转载自blog.csdn.net/chengqiuming/article/details/80711769