@FeignClient()
时间: 2023-11-07 22:58:21 浏览: 129
使用 @FeignClient 实现不使用 Eureka 的服务调用
@FeignClient是一个Spring Cloud提供的用于声明式的REST客户端的注解。它用于定义一个Feign客户端接口,该接口可以通过Feign进行远程调用其他微服务的接口。
@FeignClient标签的常用属性如下:
- name:指定FeignClient的名称,如果项目使用了Ribbon,name属性会作为微服务的名称,用于服务发现。
- url: url一般用于调试,可以手动指定@FeignClient调用的地址。
- decode404: 当发生http 404错误时,如果该字段位true,会调用decoder进行解码,否则抛出FeignException。
- configuration: Feign配置类,可以自定义Feign的Encoder、Decoder、LogLevel、Contract。
- fallback: 定义容错的处理类,当调用远程接口失败或超时时,会调用对应接口的容错逻辑,fallback指定的类必须实现@FeignClient标记的接口。
- fallbackFactory: 工厂类,用于生成fallback类示例,通过这个属性我们可以实现每个接口通用的容错逻辑,减少重复的代码。
- path: 定义当前FeignClient的统一前缀,当我们项目中配置了server.context-path,server.servlet-path时使用。
以下是一个使用@FeignClient的示例:
```java
@FeignClient(name="custorm",fallback=Hysitx.class)
public interface IRemoteCallService {
@RequestMapping(value="/custorm/getTest",method = RequestMethod.POST)
@Headers({"Content-Type: application/json;charset=UTF-8"})
List<String> test(@RequestParam("names") String[] names);
}
```
在这个示例中,@FeignClient注解用于声明一个名为"custorm"的Feign客户端接口,当调用`IRemoteCallService`接口的`test`方法时,会远程调用"custorm"微服务的"/custorm/getTest"接口。
阅读全文