【Spring Cloud】如何使用Feign实现远程调用




前言

  • 本次示例代码的文件结构如下图所示。
    在这里插入图片描述

1. 导入依赖坐标

  • order-servicepom.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

    image-20230213105023044

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

    image-20230213105821465

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

  • 5
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Cloud使用Feign是一种声明式的Web服务客户端,它简化了使用HTTP客户端进行远程服务调用的过程。Feign内部集成了Ribbon负载均衡器和Hystrix断路器,可以实现服务的负载均衡和容错处理。 要使用Feign,首先需要在项目中添加相应的依赖。在Maven项目中,可以添加以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 然后,在启动类上加上@EnableFeignClients注解来启用Feign客户端: ```java @SpringBootApplication @EnableFeignClients public class YourApplication { public static void main(String[] args) { SpringApplication.run(YourApplication.class, args); } } ``` 接下来,定义一个Feign客户端接口,使用@FeignClient注解指定要调用的服务名,并定义接口中的方法与远程服务的API接口相对应。例如: ```java @FeignClient(name = "your-service") public interface YourServiceClient { @GetMapping("/api/something") String getSomething(); } ``` 在需要调用远程服务的地方,可以通过注入此Feign客户端接口来进行调用: ```java @RestController public class YourController { private final YourServiceClient yourServiceClient; public YourController(YourServiceClient yourServiceClient) { this.yourServiceClient = yourServiceClient; } @GetMapping("/something") public String getSomething() { return yourServiceClient.getSomething(); } } ``` 以上是使用Feign进行远程服务调用的基本步骤,通过Feign可以方便地实现服务之间的通信。同时,Feign还支持对请求参数、请求头、请求体等进行配置和传递,以满足各种复杂的场景需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

自牧君

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

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

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

打赏作者

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

抵扣说明:

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

余额充值