Feign 声明式服务调用工具
1.Feign是什么
Feign是Netflix公司开发的一个声明式的REST调用客户端;
Ribbon负载均衡、Hystrix服务熔断是Spring Cloud中微服务开发非常基础的组件,一般都是同时出的,而且配置也都非常相似,每次开发都有很多相同的代码,因此Spring Cloud基于Netflix Feign整合Ribbon和Hystrix两个组件,对其进行简化,让开发工作变得更加简单
2.使用Feign实现消费者
添加依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
启动类添加注解
@SpringBootApplication @EnableFeignClients //开启Spring Cloud Feign的支持功能 public class ServiceConsumerFeignApplication {
声明服务调用接口(绑定服务提供者)
//FeignClient:设置当前的接口为一个Feign的声明式接口 //name:根据服务提供者的服务名,进而绑定服务(名称全部大写或全部小写) @FeignClient(name="springcloud-eureka-client-provider") public interface TestService { //相当于绑定服务提供者提供的/test接口方法 /* 服务提供者也提供一样的请求接口 请求路径,必须一致 参数列表,必须一致 返回值,必须一致 */ @RequestMapping("/test") String test(); }
调用服务
注意:调用服务的启动类记得添加
@EnableFeignClients(basePackages = "包名")
!!
@RestController public class FeignController { @Autowired TestService testService ; @RequestMapping("/test") public String hello() { return testService.test(); } }
3.支持服务熔断
开启feign对hystrix功能支持(支持熔断)
#开启feign对hystrix功能支持(支持熔断) feign: # 新版本circuitbreaker,旧版本hystrix属性 hystrix: enabled: true
①可进行服务熔断,但是不能获取到远程服务的异常信息 fallback
@Component public class MyFallBack implements TestService { //实现服务调用接口,并实现这个接口中所有的方法,为这个接口提供熔断的响应方法 //熔断方法,必须和调用的方法的参数列表、返回值、方法名称一致 @Override public String test() { return "test请求不可用请稍后再试"; } }
//声明服务的接口加上fallback @FeignClient(name="springcloud-eureka-client-provider", fallback= MyFallBack.class) public interface FeignService {
②进行服务熔断,并获取远程服务的异常信息 fallbackFactory
@Component public class MyFallbackFactory implements FallbackFactory<FeignService> { @Override public FeignService create(Throwable throwable) { return new FeignService() { @Override public String test() { return throwable.getMessage(); } }; } }
//声明服务的接口加上fallbackFactory @FeignClient(name="springcloud-eureka-client-provider", fallbackFactory= MyFallbackFactory.class) public interface FeignService {
熔断方法优先级:
1. Feign集成Hystrix(最高)——以上方法
2. 自定义调用Hystrix熔断方法(其次)——在方法上加 @HystrixCommand(“xxxx方法”)
3. 返回默认的熔断方法(最低)——直接在方法上加 @HystrixCommand
4.Feign方式对比RestTemplate方式
RestTemplate的Put和Delete方式的请求,没有返回值,无法接收返回的参数
Feign的Put和Delete方式的请求,是可以接收返回值的
5.Spring Cloud调用接口过程
Spring Cloud 在接口调用上,大致会经过如下几个组件配合:
Feign ----->Hystrix —>Ribbon —>Http Client(apache http components 或者 Okhttp) 具体交互流程上,如下图所示:
(1)接口化请求调用当调用被@FeignClient注解修饰的接口时,在框架内部,将请求转换成Feign的请求实例feign.Request,交由Feign框架处理。
(2)Feign:转化请求Feign是一个http请求调用的轻量级框架,可以以Java接口注解的方式调用Http请求,封装了Http调用流程。
(3)Hystrix:熔断处理机制 Feign的调用关系,会被Hystrix代理拦截,对每一个Feign调用请求,Hystrix都会将其包装成HystrixCommand,参与Hystrix的流控和熔断规则。如果请求判断需要熔断,则Hystrix直接熔断,抛出异常或者使用FallbackFactory返回熔断Fallback结果;如果通过,则将调用请求传递给Ribbon组件。
(4)Ribbon:服务地址选择 当请求传递到Ribbon之后,Ribbon会根据自身维护的服务列表,根据服务的服务质量,如平均响应时间,Load等,结合特定的规则,从列表中挑选合适的服务实例,选择好机器之后,然后将机器实例的信息请求传递给Http Client客户端,HttpClient客户端来执行真正的Http接口调用;
(5)HttpClient:Http客户端,真正执行Http调用根据上层Ribbon传递过来的请求,已经指定了服务地址,则HttpClient开始执行真正的Http请求
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)