spring boot整合openfeign实现两个微服务之间的调用。

在上一篇文章中我写了使用nacos作为服务的注册中心和配置中心,今天就讲解一下怎样使用OpenFeign实现两个乃至多个微服务之间的远程调用。

上一篇文章:springboot3整合nacos实现注册中心和配置中心(详细入门)-CSDN博客

首先,我先介绍一下什么是OpenFeign

OpenFeign是一个声明式的Web服务客户端,它简化了基于RESTful或者HTTP的远程服务调用。

(相信之前有用过的都会发现,这两种方法进行远程调用时,url路径是直接写死在代码中的。看起来非常的不美观,写起来也很生硬)

OpenFeign是Spring Cloud中的一个组件,它构建于Netflix的Feign库之上,提供了对服务调用的简单、优雅的方式。

通过OpenFeign,你可以使用注解的方式定义和编写接口,这些接口描述了你想要调用的远程服务的请求和响应。OpenFeign会根据这些接口定义自动生成实际的HTTP请求,并处理请求的编码、解码、错误处理等细节,使得远程服务调用的代码变得简洁和易于维护。

OpenFeign还支持负载均衡、重试机制、请求压缩等功能,与nacos、Eureka等Spring Cloud组件集成得很好,可以轻松地实现对远程服务的调用和管理。

总结:OpenFeign是用来发起远程调用的,使得多个微服务模块可以相互调用。

接下来让我们进行具体的实现:

我还是按照之前文章的思路进行讲解与演示:
建立一个父项目,在父项目中指定依赖的版本。建立两个子模块,用于充当生产者(producer)和消费者(consumer)。并在nacos中进行两个模块的注册;

我现在先将这两个微服务模块启动起来,并能够在nacos的控制台中看到这两个微服务。

91ba3178d7664903801225a63dddf17a.png

1de54da708f344d6859ae9002c69e0ba.png

接下来我在生产者(producer)模块中编写一个接口,在消费者(consumer)模块中进行调用。

我们知道正常情况下肯定是不能调用的,因为这两个模块的端口号不同,不能直接进行相互访问。

我们这时候就可以使用OpenFeign来进行远程的调用:

在生产者中写:

@RestController
@RequestMapping("/test")
public class TestController {

    @GetMapping
    public String test(){
        return "消费者模块的接口";
    }
    
}

写下接口之后,怎样使用OpenFeign进行远程调用呢?我们一般是再单独建立一个模块(Api)专门用来进行远程服务的调用。

建立Api模块之后,在Api模块中引入相应的依赖:

<!--        OpenFeign依赖-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
<!--        负载均衡-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-loadbalancer</artifactId>
        </dependency>

(在Spring Boot 2.4之前的版本中,默认会使用Spring Cloud Netflix Ribbon来实现RabbitMQ负载均衡,因为Ribbon是基于HTTP协议的负载均衡框架,而RabbitMQ是基于AMQP协议的消息中间件,所以在Spring Boot 2.4中取消了对Ribbon的默认依赖。现在一般使用的负载均是loadbalancer)

在Api中实现对映模块的接口,一般我们为每一个模块都建立一个包,在相应的包下完成每个模块相应的要被调用的接口

我们要实现生产者模块中刚写的接口,我们可以在Api中新建一个接口,并写上相对应的方法来进行映射:

cceffda4459e431d95872b4f7291e149.png

在这个接口上方添加@feignClient注解,表示这个接口是一个OpenFeign用户端接口,并在这个注解中写上你要调用的服务模块的微服务名称(这个名称要与注册到nacos中的微服务名称保持一致)。

在这个接口中就可以写上相应要调用的接口的路径和方法。(注意这个方法你不用去实现,OpenFeign会帮我们动态代理的,需要注意的就是路径和方法名不要写错,返回值也要保持一致。)

在消费者模块中进行远程的调用,看我们能不能调到生产者模块中定义的接口。

1、在消费者模块中引入Api模块的依赖,这样才能进行远程的调用。

<!--Api-->
        <dependency>
            <groupId>com.example</groupId>
            <artifactId>api</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

2、接下来在消费者的启动类上加入

@EnableFeignClients("com.zq.api.producer")

这表示启用OpenFeign,并在@EnableFeignClients注解中写入要使用的Feign接口所在的包。

3、调用OpenFeign接口,来完成远程接口的调用:

直接使用test就行测试:

11f4625488734ba9be14c286dfbcbc31.png

接下来我们就行测试,看能不能输出在生产者模块中所定义的接口。

8426b836a15c4eea98394b425aac5f87.png

可以看到输出了相应的结果,表明我们在消费者模块中也能调用生产者模块写的接口。

当然,我这个接口写的过于简单了点,正常的应该是基于REST风格写的get、post、put、delete四个接口,并且也传入相应的参数。

(在FeignCLient接口中要注意路径的问题,因为)@FeignClient接口不允许使用@RequestMapper注解,而我们在controller接口中,一般会默认使用@RequestMapper注解,来指定操作的数据表,所以在FeignCLient接口中,要注意将路径补充完整。

  • 6
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Cloud是一个为开发者提供了快速构建分布式系统的工具集,其中非常重要的一部分就是OpenFeignOpenFeign是一个声明式、模板化的HTTP客户端,它可以让开发者更加方便的调用HTTP接口。下面我们来详细了解一下Spring Cloud整合OpenFeign的使用方式。 首先,我们需要在pom.xml文件中添加依赖,如下所示: ``` <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>{版本号}</version> </dependency> ``` 然后,我们需要在启动类上添加@EnableFeignClients注解,表示开启Feign客户端自动配置。同时,我们还需要通过@FeignClient注解来定义接口。例如: ``` @FeignClient(name = "user-service") public interface UserFeignClient { @GetMapping("/user/findById") User findById(@RequestParam("id") Long id); } ``` 在上面的代码中,@FeignClient注解中的name属性表示调用的服务名,而接口中的findById方法就是定义的远程调用的接口。其中,@RequestParam注解表示使用@RequestParam方式传参。 最后,我们在业务代码中使用定义的接口即可。例如: ``` @RestController public class UserController { @Autowired private UserFeignClient userFeignClient; @GetMapping("/findUser") public User findUser(Long id) { return userFeignClient.findById(id); } } ``` 通过以上步骤,我们就可以方便地使用OpenFeign调用HTTP接口,实现微服务之间的远程调用整合OpenFeign有很多细节需要注意,例如如何处理调用异常、如何配置重试等等。但总体来说,Spring Cloud整合OpenFeign使用起来非常简单,是我们构建分布式系统的重要利器之一。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

张乔24

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

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

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

打赏作者

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

抵扣说明:

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

余额充值