【Spring Cloud】如何使用Feign实现远程调用
2023-09-11 14:19:28 时间
前言
- 本次示例代码的文件结构如下图所示。
1. 导入依赖坐标
-
在
order-service
的pom.xml
文件中导入 Feign 的依赖坐标。<!-- Feign远程调用客户端 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
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 负载均衡。
相关文章
- spring mvc之启动过程源码分析
- 【Spring Cloud】Spring Cloud之自定义@SpringCloudProfile注解实现@Profile注解的功能
- spring与mybatis三种整合方法
- spring cloud: zuul: 微网关-简单使用与路由配置
- [Spring学习笔记 3 ] spring 注解详解,完全注解,常用注解
- springcloud2.0以上版本_eureka控制台显示_找不到${spring.cloud.client.ipAddress}_没有显示成IP地址
- Spring Cloud Alibaba | Sentinel: 分布式系统的流量防卫兵初探
- spring boot:spring security用mysql数据库实现RBAC权限管理(spring boot 2.3.1)
- spring cloud eureka服务注册表
- Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现
- 我们为什么要使用Spring Cloud?
- Atitit 常用微服务实现 目录 1. 健康检测 max_fails与fail_timeout参 数1 1.1. spring cloud dubbo实现2 1.2. 、nginx多个tomc
- Atitit spring注解事务的demo与代码说明 目录 1.1. Spring框架中,要如何实现事务?有一个注解,@EnableTransactionManagement1 1.2. 事务管理
- MongoDB最简单的入门教程之四:使用Spring Boot操作MongoDB
- 在阿里云容器服务上开发基于Docker的Spring Cloud微服务应用(七)
- Spring-Boot + Mybatis 多数据源配置
- 【项目实战】Nacos下发路由配置实现Spring Cloud Gateway的动态路由
- 学习Spring Boot:(十)使用hibernate validation完成数据后端校验
- 总结关于spring security 使用 JWT 和 账户密码登录 整合在一起的新感悟
- 毕业设计 Spring Boot的汉服文化平台管理系统(含源码+论文)
- Spring Cloud Alibaba微服务第16章之服务容错
- 服务降级是什么?Spring Cloud如何实现?
- Spring Cloud Gateway的常用路由断言工厂
- Spring Cloud使用Zuul实现容错回退功能
- 如何使用Spring Cloud搭建高可用的Elasticsearch集群?详解Elasticsearch的安装与配置及Spring Boot集成的实现
- 慕课10、API网关-Spring Cloud Gateway
- 慕课4、Spring Cloud Alibaba是什么