赞
踩
在上一篇文章中我写了使用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的控制台中看到这两个微服务。
接下来我在生产者(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中新建一个接口,并写上相对应的方法来进行映射:
在这个接口上方添加@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就行测试:
接下来我们就行测试,看能不能输出在生产者模块中所定义的接口。
可以看到输出了相应的结果,表明我们在消费者模块中也能调用生产者模块写的接口。
当然,我这个接口写的过于简单了点,正常的应该是基于REST风格写的get、post、put、delete四个接口,并且也传入相应的参数。
(在FeignCLient接口中要注意路径的问题,因为)@FeignClient接口不允许使用@RequestMapper注解,而我们在controller接口中,一般会默认使用@RequestMapper注解,来指定操作的数据表,所以在FeignCLient接口中,要注意将路径补充完整。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。