Java小强个人技术博客站点    手机版
当前位置: 首页 >> 开源 >> SpringBoot集成Feign

SpringBoot集成Feign

48930 开源 | 2022-1-31

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的注解。

QQ截图20220131131752.jpg


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请求的环节。可以从这个方面着手分析系统的性能提升点。

推荐您阅读更多有关于“ spring HTTP springboot feing ”的文章

上一篇:Feign常用配置说明 下一篇:Centos7上搭建Nacos集群

猜你喜欢

发表评论: