SpringCloud使用Feign实现远程调用流程详细介绍 - 网站

SpringCloud使用Feign实现远程调用流程详细介绍

分类:Java · 发布时间:2023-04-16 20:23 · 阅读:6155

OpenFeign源于Netflix的Feign,是http通信的客户端。屏蔽了网络通信的细节,直接面向接口的方式开发,让开发者感知不到网络通信细节。所有远程调用,都像调用本地方法一样完成

前言

本次示例代码的文件结构如下图所示。

1. 导入依赖坐标

order-servicepom.xml 文件中导入 Feign 的依赖坐标。

 org.springframework.cloudspring-cloud-starter-openfeign

2. 开启Feign自动装配

order-service 的启动类上添加注解 @EnableFeignClients ,以开启 Feign 功能。

@MapperScan("cn.itcast.order.mapper") @SpringBootApplication @EnableFeignClients @Slf4j public class OrderApplication { public static void main(String[] args) { SpringApplication.run(OrderApplication.class, args); log.info("订单微服务启动成功"); } } 

3. 声明远程调用

Feign 采用了 Spring MVC 的注解的方式发起远程调用。只需要把发 HTTP 请求的信息声明在一个接口中,并添加注解 @FeignClient("微服务名称") ,Feign 就会自动为我们发起 HTTP 请求。通常需要声明的信息如下。

声明的信息
微服务名称userservice
请求方式GET
请求路径/user/{id}
请求参数Long id
返回值类型User

下面的代码示例演示了订单微服务 order-service 向用户微服务 user-service 发起【根据用户 ID 查询用户】的远程调用。

clients/UserClient.java

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

4. 替代RestTemplate

下面代码示例展示了使用 Feign 之前,使用 RestTemplate 发起远程调用。

@Service public class OrderService { @Autowired private OrderMapper orderMapper; // 自动注入RestTemplate,用于发起HTTP请求远程调用 @Autowired private RestTemplate restTemplate; public Order queryOrderById(Long orderId) { // 1.查询订单 Order order = orderMapper.findById(orderId); // 2.使用RestTemplate发起HTTP请求,查询订单所属用户信息 // 2.1 根据查询的订单order中的userId动态生成HTTP请求的url String url = "http://userservice/user/" + order.getUserId(); // 2.2 发送HTTP请求,实现远程调用 User user = restTemplate.getForObject(url, User.class); // 3.把远程调用获得的user封装进order对象中 order.setUser(user); // 4.返回order订单信息 return order; } } 

使用 Feign 之后,首先把 UserClient 接口自动注入 OrderService.java ,代码示例如下图所示。

@Service public class OrderService { @Autowired private OrderMapper orderMapper; // 自动注入userservice的Feign客户端,用于发起HTTP请求远程调用 @Autowired private UserClient userClient; public Order queryOrderById(Long orderId) { // 1.查询订单 Order order = orderMapper.findById(orderId); // 2.使用Feign客户端发起HTTP请求,查询订单所属用户信息 User user = userClient.getById(order.getUserId()); // 3.把远程调用获得的user封装进order对象中 order.setUser(user); // 4.返回order订单信息 return order; } } 

通过对比,使用 Feign 远程调用的编程风格非常统一,没有像 RestTemplate 那样还需要定义字符串 URL 。

5. 测试

启动订单微服务 order-service 和 2 个用户微服务 user-service

测试成功,查询订单时能远程调用用户微服务 user-service 的查询用户方法。

此外,Feign 内部还自动实现了 Ribbon 负载均衡。

到此这篇关于SpringCloud使用Feign实现远程调用流程详细介绍的文章就介绍到这了,更多相关SpringCloud Feign远程调用内容请搜索0133技术站以前的文章或继续浏览下面的相关文章希望大家以后多多支持0133技术站!

标签:
SpringCloud Feign 远程调用

相关文章

Java lombok中@Accessors注解三个属性的作用

这篇文章主要介绍了Java lombok的@Accessors注解属性解析,该注解主要作用是:当属性字段在生成 getter 和 setter 方法时,做一些相关的设置,需要的朋友可以参考下

java项目实现统一打印入参出参等日志

这篇文章主要介绍了java项目实现统一打印入参出参等日志方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

基于jdk动态代理和cglib动态代理实现及区别说明

这篇文章主要介绍了基于jdk动态代理和cglib动态代理实现及区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

java如何获得redis所有的key-value

这篇文章主要介绍了java如何获得redis所有的key-value,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

mybatis中的动态sql问题

这篇文章主要介绍了mybatis中的动态sql问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

返回分类 返回首页