1. 概述
上文Spring cloud系列六 Ribbon的功能概述、主要组件和属性文件配置已经介绍了ribbon的主要组件和用法。我们已知Spring Cloud的@Feign已经集成了ribbon的功能。本文我们介绍如何为集成在@Feign中的ribbon进行个性化配置。
主要内容如下:
- 为集成在@Feign中的ribbon进行个性化配置
- 通过@RibbonClients和@RibbonClient配置ribbon
- 通过属性文件配置ribbon
2. 工程说明
本文涉及到以下几个工程:
- cloud-registration-center:注册中心,关于这个工程,详细见之前的本系列文章
- cloud-service-ribbon:模拟服务端,注册到注册中心并对外提供调用接口
- cloud-consumer-ribbon:模拟客户端,配置个性化ribbon,通过@Fegin(含ribbon)调用服务接口
3. cloud-service-ribbon
模拟服务端,注册到注册中心并对外提供调用接口。这个服务非常简单,对外提供2个http rest接口供客户端调用
3.1. pom.xml
<parent>
<artifactId>cloudgparent</artifactId>
<groupId>com.hry.spring.cloud</groupId>
<version>0.0.1-SNAPSHOT</version>
<relativePath>../cloud-parent/pom.xml</relativePath>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cloud-service-ribbon</artifactId>
3.2. bootstrap-ribbon.yml
配置注册中心的地址和自己的服务名称cloud-ribbon-service
# port
server:
port: 11083
spring:
application:
# 本服务注册到注册到服务器的名称, 这个名称就是后面调用服务时的服务标识符
name: cloud-ribbon-service
eureka:
client:
serviceUrl:
# 服务器注册/获取服务器的zone
defaultZone: http://127.0.0.1:10761/eureka/
# defaultZone: http://192.168.21.3:10761/eureka/,http://192.168.21.4:10761/eureka/
instance:
prefer-ip-address: true
3.3. SimpleCtl.java:
提供简单的服务接口
- ribbonClientCall:立即返回一个随机字符串
- ribbonClientCallSleep:休息5s,然后返回一个随机字符串。用于测试ribbon的超时调用
@RestController
public class SimpleCtl {
private AtomicInteger count = new AtomicInteger();
private AtomicInteger sleepCount = new AtomicInteger();
@RequestMapping(value="/ribbon/simple")
public String ribbonClientCall(){
int newCount = count.incrementAndGet();
return "ribbon" + newCount + ": " + ThreadLocalRandom.current().nextInt(1000);
}
@RequestMapping(value="/ribbon/sleep")
public String ribbonClientCallSleep(){