zoukankan      html  css  js  c++  java
  • 在线教育项目-day10【服务调用-Feign】

    一、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依赖

     3.调用启动类添加注解

     4.在调用段创建一个接口,使用注解调用指定服务名称

    @FeignClient注解用于指定从哪个服务中调用功能 ,名称与被调用的服务名保持一致。
    @GetMapping注解用于对被调用的微服务进行地址映射。
    @PathVariable注解一定要指定参数名称,否则出错
    @Component注解防止,在其他位置注入CodClient时idea报错
    @FeignClient("service-vod")
    @Component
    public interface VodClient {
        //定义调用方法的路径
        @DeleteMapping("/eduvod/video/deleteAlyiVideo/{videoId}")
        public R deleteAlyiVideo(@PathVariable("videoId") String videoId);
    }

    5. 更改删除小节方法让删除小节时并且删掉视频

        @DeleteMapping("{id}")
        public R deleteVideo(@PathVariable String id) {
            EduVideo eduVideo=videoService.getById(id);
            String videosourseId=eduVideo.getVideoSourceId();
            if(!StringUtils.isEmpty(videosourseId)){
                vodClient.deleteAlyiVideo(videosourseId);
            }
            videoService.removeById(id);
            return R.OK();
        }
  • 相关阅读:
    基于tensorflow的简单线性回归模型
    msm8909平台JEITA配置和bat-V therm表合入
    开始点滴积累
    消息队列中间件(一)介绍
    Ubuntu18 的超详细常用软件安装
    IO通信模型(三)多路复用IO
    IO通信模型(二)同步非阻塞模式NIO(NonBlocking IO)
    IO通信模型(一)同步阻塞模式BIO(Blocking IO)
    Web笔记(二)Tomcat 使用总结
    const in C/C++
  • 原文地址:https://www.cnblogs.com/dmzna/p/12843492.html
Copyright © 2011-2022 走看看