1. 主要依赖
XXXClient主要依赖的是openfeign:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>2.2.2.RELEASE</version>
</dependency>
2. FeignClient不支持PATCH方法
引入httpclient依赖(注意时适配feign-core版本):
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-httpclient</artifactId>
<version>10.4.0</version>
</dependency>
3. 关于服务熔断 hystrix
在微服务调用之间,使用FeignClient如果不使用服务熔断,只要xxxClient内部除了异常,调用方得到的信息始终是500(拿不到那些业务相关的异常),为了让xxxClient内部的异常直接抛到调用方,可以如下配置(就算调用方已经定义全局异常处理也不会捕获FeignClient的异常),使用方式如下:
// 1. 在定义client时加入fallbackFactory
@FeignClient(value = "test-client", url = "http://localhost:8087/gjw-shop", fallbackFactory = TestFeignErrorFallback.class)
public interface TestClient {
//...各种方法
void fun1();
}
// 2. 定义TestFeignErrorFallback类(建议一个Client定义一个)
@Component
public class FeignErrorFallback implements FallbackFactory<TestClient> {
private static final Logger LOG = LoggerFactory.getLogger(FeignErrorFallback.class);
public static final String DEFAULT_ERR_MSG = "======= error occurred in server =======";
@Override
public TestClient create(Throwable throwable) {
String msg = throwable == null ? DEFAULT_ERR_MSG : throwable.getMessage();
if (!StringUtils.isEmpty(msg)) {
LOG.error(msg);
}
return new TestClient() {
@Override
public void fun1(Long shopComponentId) {
throw new RuntimeException(msg);
}
};
}
}
// 3. 在xxxClient调用方加入服务熔断配置
# 开启熔断
feign.hystrix.enabled = true