目录
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})