前后端分离项目知识汇总(整合SpringCloud)

本文涉及的产品
视频点播 VOD,流量+存储+转码
简介: 前后端分离项目知识汇总(整合SpringCloud)

整合SpringCloud


简介

Spring全家桶--SpringCloud(初级)_小蜗牛耶的博客-CSDN博客_springcloud开源项目

Spring全家桶--SpringCloud(中级)_小蜗牛耶的博客-CSDN博客_springcloud

Spring全家桶--SpringCloud(高级)_小蜗牛耶的博客-CSDN博客


Nacos


(1)Nacos是什么

Nacos 是阿里巴巴推出来的一个开源项目,主要用于动态服务发现、配置管理和服务管理的平台。

(2)常见的注册中心:

  1. Eureka(原生,2.0遇到性能瓶颈,现在已经停止维护)
  2. Zookeeper(支持,专业的独立产品。如:dubbo)
  3. Consul(原生,GO语言开发)
  4. Nacos

相对于 Spring Cloud Eureka 来说,Nacos 更强大。Nacos = Spring Cloud Eureka + Spring Cloud Config

(3)Nacos功能

Nacos主要提供以下四大功能:

  1. 服务发现和服务健康监测
  2. 动态配置服务
  3. 动态DNS服务
  4. 服务及其元数据管理

(4)Nacos结构图

image.png

安装

解压安装包,进入cmd运行nacos即可

image.png

image.png


服务注册


我们把后面要用的service-edu、service-oss、service-vod都加入到nacos中

怎么加呢?

1、配置依赖

<!--服务注册-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

2、添加服务配置信息

image.png

3、添加Nacos客户端注解

在客户端微服务启动类中添加注解

image.png

4、启动客户端微服务

启动注册中心

启动已注册的微服务,可以在Nacos服务列表中看到被注册的微服务

image.png


服务调用-Feign


feign 英 [feɪn] 美 [feɪn] v. 假装,装作,佯装(有某种感觉或生病、疲倦等)

Feign是一个声明式WebService客户端。使用Feign能让编写Web Service客户端更加简单。它的使用方法是定义一个服务接口然后在上面添加注解。


后端编码


删除课时的同时删除云端视频

哎,这不就出现了微服务之间互相调用的情况了吗

1、pom文件

引用feign实现远程调用

image.png

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

feign 是通过接口+注解实现微服务调用

消费者添加@EnableFeignClients开启feign

image.png

3、创建包和接口

业务逻辑接口+@FeignClient配置调用provider服务

创建client包

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

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

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

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

image.png

前提是我们vod微服务中批量删除是可以用的

image.png

4、调用微服务

课程微服务调用视频微服务

目的是删除课程同时删除视频

1、注入vod微服务中删除视频接口vodClient

image.png

2、具体流程

image.png


前端编码


还是和前面一样,我们每次点击添加小节弹框要清空

//添加小节弹框的方法
openVideo(chapterId) {
//弹框
this.dialogVideoFormVisible = true;
//清空
this.video = {};
this.fileList = [];
//设置章节id
this.video.chapterId = chapterId;
},

这次我们多添加几个小节来测试能不能同时删除

发布课程后删除课程,看视频点播还有没有视频


服务熔断-Hystrix


Spring Cloud 在接口调用上,大致会经过如下几个组件配合:

接口调用的流程很重要,我们一定要理解

自己用过这些组件的话还是很好理解的

Feign ----->Hystrix —>Ribbon —>Http Client(apache http components 或者 Okhttp)` 具体交互流程上,如下图所示:

image.png

当你调用被@FeignClient注解修饰的接口,它内部实际上是将这个调用转化成了一个feign.request。

feign框架实际上是一个http请求调用的,你这个请求发到feign了。它内部又做了http请求的封装,实际上又转化为了http请求继续发送。

发送到豪猪哥,进行流控和熔断。

之后呢豪猪哥在通过ribbon进行负载均衡,挑选合适的服务端进行发送,选择好机器之后,然后将机器实例的信息请求传递给Http Client客户端,HttpClient客户端来执行真正的Http接口调用;


Hystrix(豪猪哥)


Hystrix 是一个供分布式系统使用,提供延迟和容错功能,保证复杂的分布系统在面临不可避免的失败时,仍能有其弹性。

比如一个系统中有很多服务,如果这个系统没有隔离机制,系统随时可能挂掉。因为当某些服务不稳定的时候,可能导致级联错误,从而带来很大的风险。

下图所示,当服务b出现故障的时候,会触发熔断器,阻止了级联失败

image.png


feign结合Hystrix使用


1、添加依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>
<!--hystrix依赖,主要是用  @HystrixCommand -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
<!--服务注册-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--服务调用-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

2、配置文件中添加hystrix配置

image.png

3、在service-edu的client包里面创建熔断器的实现类

image.png

4、测试熔断器效果

我们模拟视频点播微服务宕机了,我们再去调用它,看看会不会触发hystrix

image.png

debug启动edu服务,关闭vod服务,会触发熔断器

image.png



相关文章
|
4天前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
15 2
|
1月前
|
设计模式 前端开发 Java
Spring MVC——项目创建和建立请求连接
MVC是一种软件架构设计模式,将应用分为模型、视图和控制器三部分。Spring MVC是基于MVC模式的Web框架,通过`@RequestMapping`等注解实现URL路由映射,支持GET和POST请求,并可传递参数。创建Spring MVC项目与Spring Boot类似,使用`@RestController`注解标记控制器类。
34 1
Spring MVC——项目创建和建立请求连接
|
1月前
|
Java 关系型数据库 MySQL
Maven——创建 Spring Boot项目
Maven 是一个项目管理工具,通过配置 `pom.xml` 文件自动获取所需的 jar 包,简化了项目的构建和管理过程。其核心功能包括项目构建和依赖管理,支持创建、编译、测试、打包和发布项目。Maven 仓库分为本地仓库和远程仓库,远程仓库包括中央仓库、私服和其他公共库。此外,文档还介绍了如何创建第一个 SpringBoot 项目并实现简单的 HTTP 请求响应。
115 1
Maven——创建 Spring Boot项目
|
1月前
|
Java 关系型数据库 MySQL
如何使用 maven 创建一个 Spring Boot项目
Maven 是一个强大的项目管理工具,通过配置 `pom.xml` 文件自动获取所需的 jar 包,提高开发效率。其核心功能包括项目构建和依赖管理。项目构建支持编译、测试、打包和发布等流程,而依赖管理则通过中央仓库、本地仓库和私有服务器获取和管理项目依赖。示例中展示了如何创建第一个 SpringBoot 项目并实现简单接口。
24 1
如何使用 maven 创建一个 Spring Boot项目
|
1月前
|
JSON SpringCloudAlibaba Java
Springcloud Alibaba + jdk17+nacos 项目实践
本文基于 `Springcloud Alibaba + JDK17 + Nacos2.x` 介绍了一个微服务项目的搭建过程,包括项目依赖、配置文件、开发实践中的新特性(如文本块、NPE增强、模式匹配)以及常见的问题和解决方案。通过本文,读者可以了解如何高效地搭建和开发微服务项目,并解决一些常见的开发难题。项目代码已上传至 Gitee,欢迎交流学习。
125 1
Springcloud Alibaba + jdk17+nacos 项目实践
|
1月前
|
Java 应用服务中间件 Android开发
Eclipse创建Spring项目
本文介绍了在Eclipse中创建Spring项目的步骤,包括如何配置Tomcat服务器、创建项目、部署项目到Tomcat以及添加Spring框架所需的JAR包。
53 1
Eclipse创建Spring项目
|
1月前
|
Java Spring
ij社区版如何创建spring项目
如何在IntelliJ IDEA社区版中创建Spring项目,包括安装Spring Boot Helper插件的步骤和创建过程。
65 1
ij社区版如何创建spring项目
|
1月前
|
Java Apache Maven
Java/Spring项目的包开头为什么是com?
本文介绍了 Maven 项目的初始结构,并详细解释了 Java 包命名惯例中的域名反转规则。通过域名反转(如 `com.example`),可以确保包名的唯一性,避免命名冲突,提高代码的可读性和逻辑分层。文章还讨论了域名反转的好处,包括避免命名冲突、全球唯一性、提高代码可读性和逻辑分层。最后,作者提出了一个关于包名的问题,引发读者思考。
Java/Spring项目的包开头为什么是com?
|
1月前
|
前端开发 Java 应用服务中间件
【Spring】Spring MVC的项目准备和连接建立
【Spring】Spring MVC的项目准备和连接建立
53 2
|
1月前
|
XML Java 应用服务中间件
【Spring】运行Spring Boot项目,请求响应流程分析以及404和500报错
【Spring】运行Spring Boot项目,请求响应流程分析以及404和500报错
167 2