SpringCloud开发实战(六):Feign的最佳实践

目录
SpringCloud开发实战(一):搭建SpringCloud框架
SpringCloud开发实战(二):通过RestTemplate实现远程调用
SpringCloud开发实战(三):集成Eureka注册中心
SpringCloud开发实战(四):Feign远程调用
SpringCloud开发实战(五):Feign的一些优化建议

前言

所谓最佳实践,就是使用过程中总结的经验,最好的一种使用方式。我们可以发现,Feign的客户端与服务提供者的controller代码非常相似:

feign客户端:

在这里插入图片描述

UserController:

在这里插入图片描述
这样冗余的代码我们肯定是要简化的。

一、继承方式

一样的代码我们可以通过继承来共享:

1)定义一个API接口,利用定义方法,并基于SpringMVC注解做声明。

2)Feign客户端和Controller都集成这个接口

在这里插入图片描述

优点

  • 简单
  • 实现了代码共享

缺点

  • 服务提供方、服务消费方紧耦合
  • 参数列表中的注解映射并不会继承,因此Controller中必须再次声明方法、参数列表、注解

二、抽取方式

将Feign的Client抽取为独立模块,并且把接口有关的POJO、默认的Feign配置都放到这个模块中,提供给所有消费者使用。
例如,将UserClient、User、Feign的默认配置都抽取到一个feign-api包中,所有微服务引用该依赖包,即可直接使用。

在这里插入图片描述

1. 抽取

首先创建一个module,命名为feign-api:
在这里插入图片描述
然后在feign-api中然后引入feign的starter依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

然后,order-service中编写的UserClient、User都复制到feign-api项目中

在这里插入图片描述

2. 在order-service中使用feign-api

首先,删除order-service中的UserClient、User等类或接口。在order-service的pom文件中引入feign-api的依赖:

<dependency>
	<groupId>org.demo</groupId>
	<artifactId>feign-api</artifactId>
	<version>1.0</version>
</dependency>

修改order-service中的所有与上述组件有关的导包部分,改成导入feign-api中的包

3. 测试

在这里插入图片描述

注:解决扫描包的问题

如果出现下面图片所示问题,代表包的扫描位置有问题在这里插入图片描述

解决方式一

在启动类上指定Feign应该扫描的包:

@EnableFeignClients(basePackages = "org.demo.client")

解决方式二

或者在启动类上指定需要加载的Client接口:

@EnableFeignClients(clients = {UserClient.class})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

每天吃八顿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值