一、Feign

基本概念

  • Feign是Netflix开发的声明式、模板化的HTTP客户端, Feign可以帮助我们更快捷、优雅地调用HTTP API。
  • 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时自行封装服务调用客户端的开发量。

依赖

  1. <!--服务调用-->
  2. <dependency>
  3. <groupId>org.springframework.cloud</groupId>
  4. <artifactId>spring-cloud-starter-openfeign</artifactId>
  5. </dependency>

使用

1. 在调用端的启动类添加注解

  1. @EnableFeignClients

2. 创建包和接口

创建client包

@FeignClient注解用于指定从哪个服务中调用功能 ,名称与被调用的服务名保持一致。

@GetMapping注解用于对被调用的微服务进行地址映射。

@PathVariable注解一定要指定参数名称,否则出错

@Component注解防止,在其他位置注入CodClient时idea报错

  1. @FeignClient("service-vod")
  2. @Component
  3. public interface VodClient {
  4. @DeleteMapping(value = "/eduvod/vod/video/{videoId}")
  5. public R removeVideo(@PathVariable("videoId") String videoId);
  6. }

3. 调用微服务

在调用端的VideoServiceImpl中调用client中的方法

  1. @Override
  2. public boolean removeVideoById(String id) {
  3. //查询云端视频id
  4. Video video = baseMapper.selectById(id);
  5. String videoSourceId = video.getVideoSourceId();
  6. //删除视频资源
  7. if(!StringUtils.isEmpty(videoSourceId)){
  8. vodClient.removeVideo(videoSourceId);
  9. }
  10. Integer result = baseMapper.deleteById(id);
  11. return null != result && result > 0;
  12. }