SpringCloud之@FeignClient()注解的使用方式

Posted Ctrl练习生-谢哥哥blog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringCloud之@FeignClient()注解的使用方式相关的知识,希望对你有一定的参考价值。

这篇文章主要介绍了SpringCloud中@FeignClient()注解的使用方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教。

文章目录


1、@FeignClient()注解的使用

由于SpringCloud采用分布式微服务架构,难免在各个子模块下存在模块方法互相调用的情况。比如A服务要调用B服务的方法
@FeignClient()注解就是为了解决这个问题的
@FeignClient()注解的源码要求它必须在Interface接口上使用( FeignClient注解被@Target(ElementType.TYPE)修饰,表示FeignClient注解的作用目标在接口上)

2、@FeignClient标签的常用属性

value:服务名(接口提供方的服务名)
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的统一前缀
此外还要求服务的启动类要有@EnableFeignClients 注解才能使Fegin生效

SpringCloud搭建各种微服务之后,服务间通常存在相互调用的需求,SpringCloud提供了@FeignClient 注解非常优雅的解决了这个问题

3、@FeignClient()简单样例

首先,保证所需要服务都注册成功
我一共有三个服务注册成功。分别为:服务A、服务B、服务C
如下:

给它们的角色
服务A:接口提供方
服务B:接口使用方
服务C:编写远程调用Feign

3.1、调用Get请求带参接口

服务B调用服务A中的getTest-a,有参数a和b

服务A的controller层

@GetMapping("getTest-a")
public R<?> getTest(String a, Integer b)
    String data = "服务A返回信息===a:" + a + "===b:" + b;
    return R.ok(data);

服务C中创建TestClient,用于给服务B调用
注意:
Feign 调用接口参数问题;多个值传递用:@RequestParam(“xxx”)
单个值传递:@RequestBody

@FeignClient(contextId = "testClient", value = "服务A")
public interface TestClient 

    @GetMapping("getTest-a")
    R<?> getTest(@RequestParam("a") String a, @RequestParam("b") Integer b);

服务B调用

// 注入服务C的TestClient
@Autowired
private TestClient testClient;

@GetMapping("getTest-b")
public R<?> getTest()
    return testClient.getTest("服务B成功调用", 666);

测试

3.2、调用Post请求不带参接口

服务B调用服务A中的postTest-a,无参数

服务A的controller层

@GetMapping("getTest-a")
public R<?> getTest(String a, Integer b)
    String data = "服务A返回信息===a:" + a + "===b:" + b;
    return R.ok(data);


@PostMapping("postTest-a")
public R<?> postTest()
    String data = "服务A返回信息";
    return R.ok(data);

服务C的TestClient添加接口

@FeignClient(contextId = "testClient", value = "服务A")
public interface TestClient 

    @GetMapping("getTest-a")
    R<?> getTest(@RequestParam("a") String a, @RequestParam("b") Integer b);

    @PostMapping("postTest-a")
    R<?> postTest();

服务B调用

@GetMapping("getTest-b")
public R<?> getTest()
    return testClient.getTest("服务B成功调用", 666);


@PostMapping("postTest-b")
public R<?> postTest()
    return testClient.postTest();

测试

如果觉得不错,可以点赞+收藏或者关注下博主。感谢阅读!

以上是关于SpringCloud之@FeignClient()注解的使用方式的主要内容,如果未能解决你的问题,请参考以下文章

SpringCloud之@FeignClient()注解的使用方式

SpringCloud原理:OpenFeign之FeignClient动态代理生成原理

SpringCloud | FeignClient和Ribbon重试机制区别与联系

Springcloud踩坑记---使用feignclient远程调用服务404

SpringCloud中FeignClient

FeignClient注解及参数问题---SpringCloud微服务