前言
在开发 Spring Cloud 微服务的时候,我们知道,服务之间都是以 HTTP 接口的形式对外提供服务的,因此消费者在进行调用的时候,底层就是通过 HTTP Client 的这种方式进行访问。当然我们可以使用JDK原生的 URLConnection、Apache 的 HTTP Client、Netty 异步 Http Client,Spring 的 RestTemplate 去实现服务间的调用。但是最方便、最优雅的方式是通过 Spring Cloud Open Feign 进行服务间的调用 Spring Cloud 对 Feign 进行了增强,使 Feign 支持 Spring Mvc 的注解,并整合了 Ribbon 等,从而让 Feign 的使用更加方便。
Feign的使用步骤
1、引入依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2、主启动类上添加@EnableFeignClients注解
@SpringBootApplication
@EnableFeignClients
public class OrderServiceApplication {
public static void main(String[] args) {
SpringApplication.run(OrderServiceApplication.class, args);
}
}
3、编写FeginClient接口
@FeignClient("product-service") //被调用服务的名称
public interface ProductClient {
@GetMapping("/product/{id}") //请求的路径和参数
Product findById(@PathVariable Long id);
}
4、使用Fegin进行远程调用
//注入ProductClient
@Autowired
private ProductClient productClient;
public Order getOrderById(Long id){
//1.模拟查询订单
Order order = new Order(id,88L,10L, LocalDateTime.now(),null);
//2.feign的远程调用
Product product = productClient.findById(order.getProductId());
//3.封装product到order
order.setProduct(product);
//4.返回order
return order;