Feign的作用
把Rest的请求进行隐藏,伪装成类似SpringMVC的Controller一样。你不用再自己拼接url,拼接参数等等操作,一切都交给Feign去做。
使用
包装的几个关键要素
- 请求方法
- 请求参数
- 请求路径
- 返回结果类型
- 服务名称
引入依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
调用方的启动类中引入注解
@EnableFeignClients
编写一个接口,用于包装Rest请求
不再手动调用restTemplate,直接注入接口来调用。
Feign的Ribbon支持
无需额外引入依赖,Feign内置有
可以通过ribbon.xx来进行全局配置。也可以通过服务名.ribbon.xx来对指定服务配置
user-service:
ribbon:
ConnectTimeout: 250 # 连接超时时间(ms)
ReadTimeout: 1000 # 通信超时时间(ms)
OkToRetryOnAllOperations: true # 是否对所有操作重试
MaxAutoRetriesNextServer: 1 # 同一服务不同实例的重试次数
MaxAutoRetries: 1 # 同一实例的重试次数
Hystix支持
默认情况下Feign中的Hystrix是关闭的需要手动开启
feign:
hystrix:
enabled: true # 开启Feign的熔断功能
实现之前的client接口中的方法作为其fallback降级处理逻辑
再在原注解中加入该实现类