图片.png

一、Feign

1、基本概念

  • 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、在service模块添加pom依赖

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

3、在调用端的启动类添加注解

  1. @EnableFeignClients

4、创建包和接口

创建client包
@FeignClient注解用于指定从哪个服务中调用功能 ,名称与被调用的服务名保持一致。
@GetMapping注解用于对被调用的微服务进行地址映射。
@PathVariable注解一定要指定参数名称,否则出错
@Component注解防止,在其他位置注入CodClient时idea报错

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

5、调用微服务

在调用端的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. }

6、测试

启动相关微服务
测试删除课时的功能