Feign远程调用在工作中的两种最佳使用方式(抽取父接口、抽取独立模块)

引言

在使用Feign进行远程调用的实际工作当中,你会发现,feign的客户端与服务提供者的Controller代码十分类型。

//Feign客户端

@FeignClient("")
public interface UserClient{
	@GetMapping("/user/{id}")
	User findById(@PathVariable("id") Long id);
}


//Controller
@RestController
public class UserController{
	@GetMapping("/user/{id}")
	public User findById(@PathVariable("id") Long id){
		return userService.getUserById(id);
	}
}

通过以上代码分析,可以使用两种方法来优化远程调用。
第一种,抽取父接口。众所周知,Feign的客户端实际上是一个接口,而Controller则是一个类。我们可以抽取相同的代码,编写一个共同的接口A。Feign客户端extends该接口A,Controller则实现该implement该接口A。

第二种,抽取独立模块。将所有的Feign的客户端抽取成一个独立模块,在需要使用的工程上,引入该模块依赖,使用即可。

第一种:抽取父接口

//父接口
public interface UserAPI{
	@GetMapping("/user/{id}")
	User findById(@PathVariable("id") Long id);
}

//Feign客户端

@FeignClient("")
public interface UserClient extends UserAPI{
	//无需编写。
}


//Controller
@RestController
public class UserController implement UserAPI{
	@GetMapping("/user/{id}")
	public User findById(@PathVariable("id") Long id){
		return userService.getUserById(id);
	}
}

第二种:抽取独立模块

将所有的Client端单独放在一个模块或者工程里面,包括POJO。
如下:在这里插入图片描述
比如:order工程下需要用到该远程调用,则在pom文件下引入该依赖坐标。

<dependency>
    <groupId>xxxxx</groupId>
    <artifactId>feign-api</artifactId>
    <version>1.0</version>
</dependency>

之后在需要进行远程调用的地方进行调用即可。

注意:如出现扫描包问题,可在开启Feign的注解上增加其路径,可以在注解上指定要加载的client接口。

@EnableFeignClients(basePackages = "xxx.xxx.clients")
//或者
@EnableFeignClients(clients = {xxxClient.class})

总结:

两种都是很不错的Feign远程调研的实践例子。第一种充分利用了Java的特性来实现。第二种则利用模块划分及引入来实践。希望在工作中能帮助到各位小伙伴。谢谢~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Feign是一个基于注解的声明式HTTP客户端,它可以简化服务之间的远程调用使用Feign可以像调用本地方法一样调用远程服务。 要使用Feign进行远程调用,需要进行以下几个步骤: 1. 添加依赖:在项目的pom.xml文件添加Feign的依赖。例如,对于Spring Boot项目,可以添加以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 2. 创建Feign客户端接口:定义一个Java接口使用`@FeignClient`注解指定要调用的远程服务的名称。在接口定义需要调用的方法,并使用`@RequestMapping`等注解指定远程服务的URL和参数。 ```java @FeignClient(name = "remote-service") public interface RemoteServiceClient { @RequestMapping(method = RequestMethod.GET, value = "/api/resource") String getResource(); } ``` 3. 配置Feign客户端:在Spring Boot应用程序的配置文件,可以配置Feign客户端的一些属性,如远程服务的URL、连接超时时间等。例如: ```yaml spring: application: name: my-application cloud: feign: client: config: remote-service: connect-timeout: 5000 read-timeout: 5000 ``` 4. 使用Feign客户端:在需要调用远程服务的地方,通过依赖注入的方式使用Feign客户端接口,并调用定义的方法即可。 ```java @Autowired private RemoteServiceClient remoteServiceClient; public void doRemoteCall() { String resource = remoteServiceClient.getResource(); // 处理返回的资源数据 } ``` 通过以上步骤,就可以使用Feign进行远程调用了。Feign会根据接口定义自动生成对应的HTTP请求,并将结果转换为指定类型返回。同时,Feign还提供了负载均衡、熔断等功能,可以更方便地实现微服务架构的服务调用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

IT学习小镇

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

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

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

打赏作者

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

抵扣说明:

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

余额充值