当前位置:   article > 正文

spring boot整合openfeign实现两个微服务之间的调用。_使用spring boot开发微服务处理调用和数据交互

使用spring boot开发微服务处理调用和数据交互

在上一篇文章中我写了使用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接口中,要注意将路径补充完整。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小蓝xlanll/article/detail/428821
推荐阅读
相关标签
  

闽ICP备14008679号