一 介绍
很多场景下,可能根据需要自定义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微服务
测试结果是随机访问