Feign是一个声明式的http客户端,官方地址:https://github.com/OpenFeign/feign
Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。
在Spring Cloud中,使用Feign非常简单——创建一个接口,并在接口上添加一些注解,代码就完成了。Feign支持多种注解,例如Feign自带的注解或者JAX-RS注解等。
Spring Cloud对Feign进行了增强,使Feign支持了Spring MVC注解,并整合了Ribbon和Eureka,从而让Feign的使用更加方便。
Spring Cloud Feign是基于Netflix feign实现,整合了Spring Cloud Ribbon和Spring Cloud Hystrix,除了提供这两者的强大功能外,还提供了一种声明式的Web服务客户端定义的方式。
Spring Cloud Feign帮助我们定义和实现依赖服务接口的定义。在Spring Cloud feign的实现下,只需要创建一个接口并用注解方式配置它,即可完成服务提供方的接口绑定,简化了在使用Spring Cloud Ribbon时自行封装服务调用客户端的开发量。
Spring Cloud Feign具备可插拔的注解支持,支持Feign注解、JAX-RS注解和Spring MVC的注解。
Feign替代RestTemplate
pom文件中引入feign的依赖:
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency>
添加注解启动类添加注解开启Feign的功能:
@SpringBootApplication @EnableFeignClients public class OrderApplication {}
编写Feign的客户端
/** * @Auther: Java小强 * @Date: 2022/1/30 - 23:57 * @Decsription: cn.itcast.order.client * @Version: 1.0 */ @FeignClient("userservice") public interface UserClient { @GetMapping("/user/getUser/{id}") User queryById(@PathVariable("id") Long id); }
userservice就是nacos注册中心及服务提供者的名称,它解析结果就是IP+端口。
下面的方法就是和服务提供者一样
因为我们在服务提供者的Controller上增加了公共路径定义/user,所以Feign的方法这里要加上这部分,组成完整的URL。
@Slf4j @RestController @RequestMapping("/user") //@RefreshScope public class UserController { @GetMapping("/getUser/{id}") public User queryById(@PathVariable("id") Long id) { return userService.queryById(id); } }
这样,Feign就可以帮助我们发送http请求,无需自己使用RestTemplate来发送了。
使用,如下代码将会变得非常优雅简单
@Autowired private UserClient userClient; User user = userClient.queryById(userID);
Feign框架比较小巧,在处理请求转换和消息解析的过程中,基本上没什么时间消耗。真正影响性能的,是处理Http请求的环节。可以从这个方面着手分析系统的性能提升点。