【SpringCloud】之入门级及nacos的集成使用

  🎉🎉欢迎来到我的CSDN主页!🎉🎉

🏅我是君易--鑨,一个在CSDN分享笔记的博主。📚📚

🌟推荐给大家我的博客专栏《SpringCloud开发之入门级及nacos》。🎯🎯

🎁如果感觉还不错的话请给我关注加三连吧!🎁🎁


一、SpringCloud简介

1. 基本概述

        Spring Cloud 是一个用于构建分布式系统的开源框架,它基于 Java 编程语言,并以 Spring 框架基础。Spring Cloud 提供了一组工具和库,用于快速开发分布式系统中的各种模块,例如服务发现、配置管理、负载均衡、断路器、数据流等。

2. 其组件和功能

        以下是 Spring Cloud 的一些主要组件和功能:

Spring Cloud 的一些主要组件和功能
组件和功能说明
服务发现(Service Discovery)Spring Cloud 提供了服务发现机制,使得微服务能够动态注册和发现其他服务。这有助于构建弹性和可伸缩的系统。

配置管理(Configuration Management)

Spring Cloud Config 允许将配置集中管理,使得微服务应用能够更灵活地配置和更新。
负载均衡(Load Balancing)Spring Cloud 支持多种负载均衡策略,帮助分散请求负载,提高系统的可用性和性能。
断路器模式(Circuit Breaker)Spring Cloud Netflix Hystrix 提供了断路器模式的实现,用于防止分布式系统中的故障在一定程度上影响整个系统。
API 网关(API Gateway)Spring Cloud Gateway 和 Zuul 是两个常用的 API 网关,用于管理微服务的路由和过滤。
分布式追踪(Distributed Tracing)Spring Cloud Sleuth 和 Zipkin 提供了分布式系统中请求的跟踪和监控功能,有助于快速定位和解决问题。
分布式数据流(Data Flow)Spring Cloud Data Flow 是一个用于构建和部署大规模数据处理系统的框架。
消息驱动(Messaging)Spring Cloud Stream 和 Spring Cloud Bus 提供了消息驱动的能力,支持事件驱动架构。

         总体而言,Spring Cloud 为构建微服务架构提供了一整套解决方案,使得开发者能够更容易地实现微服务架构中的各种功能和模块,同时提供了一些对分布式系统中常见问题的解决方案。它建立在 Spring Boot 的基础之上,充分利用了 Spring 生态系统的优势。

组成图解

二、核心组件业务讲解

1. Eureka 

        Eureka是微服务架构中的注册中心,专门负责服务的注册与发现。

        订单服务想要调用库存服务、仓储服务,或者是积分服务,怎么调用?
        订单服务压根儿就不知道人家库存服务在哪台机器上啊!他就算想要发起一个请求,都不知道发送给 谁,有心无力。

 图解说明

Eureka Client:负责将这个服务的信息注册到Eureka Server

Eureka Server :注册中心,里面有一个注册表,保存了各个服务所在的机器和端口号

2.  Feign

        现在订单服务确实知道库存服务、积分服务、仓库服务在哪里了,同时也监听着哪些端口号了。

        但是新问题又来了:如何从订单服务跟其他服务建立网络连接,接着发送请求过去。

图解说明

3.  Ribbon

集群服务:库存服务部署在了 5 台机器上
192.168.169:9000
192.168.170:9000
192.168.171:9000
192.168.172:9000
192.168.173:9000
        Ribbon就是专门解决这个问题的。它的作用是负载均衡,会帮你在每次请求时选择一台机器,均匀的把
        请求分发到各个机器上
        首先Ribbon 会从 Eureka Client 里获取到对应的服务注册表,也就知道了所有的服务都部署在了哪些机器上,在监听哪些端口号。
        然后Ribbon 就可以使用默认的 Round Robin 算法,从中选择一台机器
Feign 就会针对这台机器,构造并发起请求。

 图解演示说明

4. Hystrix

        在微服务架构里,一个系统会有很多的服务。
        以上面的业务场景为例:订单服务在一个业务流程里需要调用三个服务。
        现在假设订单服务自己最多只有100 个线程可以处理请求,然后呢,积分服务不幸的挂了,每次订单服 务调用积分服务的时候,都会卡住几秒钟,然后抛出— 个超时异常 出现问题: 微服务架构中的服务雪崩问题。 如果系统处于高并发的场景下,大量请求涌过来的时候,订单服务的100 个线程都会卡在请求积分 服务这块。导致订单服务没有一个线程可以处理请求,然后就会导致别人请求订单服务的时候,发现订单服务也挂了,不响应任何请求了
Hystrix 是隔离、熔断以及降级的一个框架。
        比如订单服务请求库存服务是一个线程池,请求仓储服务是一个线程池,请求积分服务是一个线程池。 每个线程池里的线程就仅仅用于请求那个服务。
        积分服务挂了
        会导致订单服务里的那个用来调用积分服务的线程都卡死不能工作!
但是由于订单服务调用库存服务、仓储服务的这两个线程池都是正常工作的,所以这两个服务不会受到 任何影响。 这个时候如果别人请求订单服务,订单服务还是可以正常调用库存服务扣减库存,调用仓储服务通知发货。
        只不过调用积分服务的时候,每次都会报错。但是如果积分服务都挂了,每次调用都要去卡住几秒钟!所以我们直接对积分服务熔断不就得了,比如在5 分钟内请求积分服务直接就返回了,不要去走网络请求卡住几秒钟,这个过程,就是所谓的熔断!
        那人家又说,兄弟,积分服务挂了你就熔断,好歹你干点儿什么啊!别啥都不干就直接返回啊?没问题,咱们就来个降级: 每次调用积分服务,你就在数据库里记录一条消息,说给某某用户增加了多少积分,因为积分服务挂 了,导致没增加成功!
        这样等积分服务恢复了,你可以根据这些记录手工加一下积分。这个过程,就是所谓的降级

图解演示说明

 5. Zuul

        这个组件是负责网络路由的。
        一 般微服务架构中都必然会设计一个网关在里面,像android、 ios pc 前端、微信小程序、 H5 等等。 不用去关心后端有几百个服务,就知道有一个网关,所有请求都往网关走,网关会根据请求中的一些特 征,将请求转发给后端的各个服务。有一个网关之后,还有很多好处,比如可以做统一的降级、限流、认证授权、安全,等等。
         组件总和:
        Eureka:各个服务启动时, Eureka Client 都会将服务注册到 Eureka Server ,并 Eureka Client 还 可以反过来从Eureka Server 拉取注册表,从而知道其他服务在哪里
        Ribbon:服务间发起请求的时候,基于 Ribbon 做负载均衡,从一个服务的多台机器中选择一台。
        Feign:基于 Feign 的动态代理机制,根据注解和选择的机器,拼接请求 URL 地址,发起请求。
        Hystrix:发起请求是通过 Hystrix 的线程池来走的,不同的服务走不同的线程池,实现了不同服务。调用的隔离,避免了服务雪崩的问题
        Zuul:如果前端、移动端要调用后端系统,统一从 Zuul 网关进入,由 Zuul 网关转发请求给对应的服务。
         流程:
1. 请求统一通过 API 网关( Zuul )来访问内部服务 .
2. 网关接收到请求后,从注册中心( Eureka )获取可用服务
3. Ribbon 进行均衡负载后,分发到后端具体实例
4. 微服务之间通过 Feign 进行通信处理业务
5. Hystrix 负责处理服务超时熔断

 图解演示说明

 三、springCloud关系

        Spring Cloud 包含很多子项目: Netflix Alibaba 两个标准使用最多

 1. Spring Cloud Netflix 第一代

        针对多种 Netflix 组件提供的开发工具包,其中包括 Eureka Ribbon Feign Hystrix Zuul、 Archaius 等。
  • Netflix Eureka:一个基于 Rest 服务的服务治理组件,包括服务注册中心、服务注册与服务发现机 制的实现,实现了云端负载均衡和中间层服务器的故障转移。
  • Netflix Ribbon:客户端负载均衡的服务调用组件。
  • Netflix Hystrix:容错管理工具,实现断路器模式,通过控制服务的节点,从而对延迟和故障提供 更强大的容错能力。
  • Netflix Feign:基于 Ribbon Hystrix 的声明式服务调用组件。
  • Netflix Zuul:微服务网关,提供动态路由,访问过滤等服务。
  • Netflix Archaius:配置管理 API,包含一系列配置管理 API,提供动态类型化属性、线程安全配置 操作、轮询框架、回调机制等功能。

2. Spring Cloud Alibaba 第二代 

        同 Spring Cloud 一样, Spring Cloud Alibaba 也是一套微服务解决方案。
        Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的 必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。
        依托 Spring Cloud Alibaba ,只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统。

「阿里开源组件」  

  1. Nacos:阿里巴巴开源产品,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平 台。
  2. Sentinel:面向分布式服务架构的轻量级流量控制产品,把流量作为切入点,从流量控制、熔断降 级、系统负载保护等多个维度保护服务的稳定性。
  3. RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的 消息发布与订阅服务。
  4. DubboApache Dubbo™ 是一款高性能 Java RPC 框架,用于实现服务通信。
  5. Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。

「阿里商业化组件」

  1. Alibaba Cloud ACM:一款在分布式架构环境中对应用配置进行集中管理和推送的应用配置中心产 品。
  2. Alibaba Cloud OSS:阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供 的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访 问任意类型的数据。
  3. Alibaba Cloud SchedulerX:阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、 高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。
  4. Alibaba Cloud SMS:覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速 搭建客户触达通道。

 二者区别

四、SpringCloud的集成使用

1. 创建一个主项目

        我们在开发工具中创建一个主项目用于定义一些pom依赖,防止一些子项目重复的引入。我们创建一个Maven项目作为主项目。(确保在又网络的情况下)

         然后我们对其的pom文件进行修改。

 

 

2. 导入我们所需的依赖

        我们这里导入我们所需要的一些依赖,这里注意版本很重要,可以借鉴下述网址进行获取相应的依赖,获取直接使用我所提供的版本进行操作使用。(因为版本不同可能会导致后续开发出现问题以及方法使用出现问题)

版本关系
SpringBoot
SpringCloud
Spring Cloud Dependencies
SpringCloud 中文学习指南
Spring Cloud Alibaba

2.1 定义我们所需要的版本

        在定义之前我们先把一些创建项目生成自带的给删除掉

         接下来定义我们的版本

<!--  定义版本--><properties><spring-boot.version>2.4.1</spring-boot.version><spring-cloud.version>2020.0.0</spring-cloud.version><spring-cloud-alibaba.version>2021.1</spring-cloud-alibaba.version></properties>

 

        然后就是导入所需的pom依赖,但是我们的pom依赖不是导入在 dependencies的标签中;而是dependencyManagement的标签中,该标签使来定义依赖的,并不能使用,只用于提供版本。

<!--  下面是导入我们的依赖--><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>${spring-boot.version}</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>${spring-cloud.version}</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>${spring-cloud-alibaba.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>

         我们的主项目不写代码,因此删除那些生成自带的东西。只保留pom.xml文件

 

3. 创建子项目用于写代码

        我们在主项目下新建两个新的项目,项目是SpringBoot项目。注意创建时的依赖选择

 

         创建好的子项目的pom文件中将自带的版本以及依赖直接删除不要,还有跳过编译的也要去掉

        在子项目中继承主项目的依赖

 <parent><groupId>com.yx</groupId><artifactId>cloud</artifactId><version>1.0-SNAPSHOT</version></parent>

         我们可以对其子项目版本介绍的pom文件的进行删减,保留如下即可

 

4. 主项目定义依赖 

         在主项目中定义其依赖

 

        在我们主项目中引入了依赖之后,我们对应的子项目中就会有了,但是我们对应的子项目可以根据自己的业务需求导入自身所需要的依赖 

 5. 主项目中定义子项目

        不标记子项目无法使用主项目定义的依赖

 6. 模拟

        生成者生产鸡腿,消费者拿到鸡腿。需要在两个子项目中编写两个不同的控制类

 6.1 生产者

ProviderController.java
package com.yx.provider;import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class ProviderController {
@RequestMapping("/run")
public String run() {
return "🍗";
}
}

       yml文件的端口号不要与消费者一致

 

6.2 消费者

 ConsumerController.java
package com.yx.consumer;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;@RestController
public class ConsumerController {//restTemplate相当于HttpClient,用于发送请求@RequestMapping
public String run() {
//    实例化restTemplateRestTemplate restTemplate = new RestTemplate();
//    跳转到生产者去return restTemplate.getForObject("http://localhost:8080/run", String.class);
}
}

        对应的yml文件的端口不要一致

 

 测试

        将两个项目运行启动测试 

        两个项目的调用实现了。 

五、 nacos的集成使用

1. 下载访问

         我们使用 nacos先去到官网进行下载

网址:Nacos 快速开始

        下载完成之后,解压在bin目录下有启动文件

         双击启动

         在网页中访问指定地址

http://localhost:8848/nacos 

        登陆之后,会进入到nacos中 

2. 将子项目注册到nacos中

         在对应的子项目的yml文件做改动

2.1 生成者

2.2 消费者

        导入nacos的pom依赖到主项目中

 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>

 

        还要在每个子项目的启动类上标注使用nacos

 

 

3. 启动项目进行查看

        我们启动运行项目,在nacos官网中进行查看

        我们可以将消费者的跳转路径进行更改 

 4. 导入ribbon的依赖

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-loadbalancer</artifactId>
</dependency>

 

ribbon 状态 : 停止更新
替代方案 : Spring Cloud Loadbalancer

          因为我们的restTemplate不具备负载均衡,因此要导入一个配置类或者将方法写在启动类

消费者

         重启服务即可使用,测试


 🎉🎉本期的博客分享到此结束🎉🎉

📚📚各位老铁慢慢消化📚📚

🎯🎯下期博客博主会带来新货🎯🎯

🎁三连加关注,阅读不迷路 !🎁

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/610161.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

设计模式面试

C 面向对象设计 封装&#xff1a;隐藏内部实现继承&#xff1a;复用现有代码多态&#xff1a;改写对象行为 设计模式关键在于分解和抽象; 设计模式的主要目的是易于变化 面向对象设计原则–比设计模式更加重要 违背了设计原则&#xff0c;设计模式是错误的。 依赖倒置原则…

你们做外贸主要的获客渠道有哪些?

昨天跟一个同行朋友聊天&#xff0c;他原本主打产品是做动力类的&#xff0c;这两年竞争太大&#xff0c;订单也减少了很多。为了求发展&#xff0c;就拓品了&#xff0c;而拓展的新品刚好是我们这一块&#xff0c;而且非常迅速地找到场地把生产线弄了起来&#xff0c;还不断扩…

严格次小生成树(LCA+Kruskal)

一、次小生成树 次小生成树是指在给定的无向图中&#xff0c;如果存在最小生成树和次小生成树&#xff0c;那么对于任何一颗最小生成树来看&#xff0c;都存在一颗次小生成树&#xff0c;使得这两棵树只有一条边不同。次小生成树的边权和大于等于最小生成树的另一颗树&#xf…

RT-DETR 更换骨干网络之 MobileNetV3 | 《搜寻 MobileNetV3》

论文地址:https://arxiv.org/abs/1905.02244 代码地址:https://github.com/xiaolai-sqlai/mobilenetv3 我们展示了基于互补搜索技术和新颖架构设计相结合的下一代 MobileNets。MobileNetV3通过结合硬件感知网络架构搜索(NAS)和 NetAdapt算法对移动设计如何协同工作,利用互…

IntelliJ IDEA如何使用固定地址公网远程访问本地Mysql数据库

文章目录 1. 本地连接测试2. Windows安装Cpolar3. 配置Mysql公网地址4. IDEA远程连接Mysql小结 5. 固定连接公网地址6. 固定地址连接测试 IDEA作为Java开发最主力的工具&#xff0c;在开发过程中需要经常用到数据库&#xff0c;如Mysql数据库&#xff0c;但是在IDEA中只能连接本…

前端面试题集合五(css)

CSS 面试知识点总结 本部分主要是笔者在复习 CSS 相关知识和一些相关面试题时所做的笔记&#xff0c;如果出现错误&#xff0c;希望大家指出&#xff01; 目录 1.介绍一下标准的 CSS 的盒子模型&#xff1f;低版本 IE 的盒子模型有什么不同的&#xff1f;2.CSS 选择符有哪些…

Linux学习记录(二)

组管理和权限管理 组的基本介绍 在Linux中每个用户必须属于一个组&#xff0c;不能独立于组外&#xff1b; 在Linux中每个文件有所有者、所在组、其他组的概念。 一般来说谁创建了文件&#xff0c;谁就是文件的所有者&#xff0c;用户所在组就是该文件的所在组。 查看文件的…

Apache ECharts | 一个数据可视化图表库

文章目录 1、简介1.1、主要特点1.2、使用场景 2、安装方式一&#xff1a;从下载的源代码或编译产物安装方法二&#xff1a;从 npm 安装方法三&#xff1a;⭐定制安装echarts.js 3、使用 官网&#xff1a; 英语&#xff1a;https://echarts.apache.org/en/index.html 中文&a…

Vue-4、单向数据绑定与双向数据绑定

1、单向数据绑定 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>数据绑定</title><!--引入vue--><script type"text/javascript" src"https://cdn.jsdelivr.net/npm/…

linux(ubuntu)中crontab定时器命令详解 以及windows中定时器

linux&#xff08;ubuntu&#xff09;中crontab定时器命令详解 crontab 是一个用于创建、编辑和管理用户的定时任务的命令&#xff0c;它可以让用户在指定的时间自动执行指定的命令或脚本。 基本语法 -e&#xff1a;编辑用户的 crontab 文件&#xff1b;-l&#xff1a;列出用…

【机器学习】常见算法详解第2篇:K近邻算法各种距离度量(已分享,附代码)

本系列文章md笔记&#xff08;已分享&#xff09;主要讨论机器学习算法相关知识。机器学习算法文章笔记以算法、案例为驱动的学习&#xff0c;伴随浅显易懂的数学知识&#xff0c;让大家掌握机器学习常见算法原理&#xff0c;应用Scikit-learn实现机器学习算法的应用&#xff0…

Java18:网络编程

一.对象序列化&#xff1a; 1.对象流&#xff1a; ObjectInputStream 和 ObjectOutputStream 2.作用&#xff1a; ObjectOutputSteam&#xff1a;内存中的对象-->存储中的文件&#xff0c;通过网络传输出去 ObjectInputStream:存储中的文件&#xff0c;通过网络传输出去…

【漏洞复现】ActiveMQ文件上传漏洞(CVE-2016-3088)

Nx01 产品简介 Apache ActiveMQ是Apache软件基金会所研发的开放源代码消息中间件。ActiveMQ是消息队列服务&#xff0c;是面向消息中间件&#xff08;MOM&#xff09;的最终实现&#xff0c;它为企业消息传递提供高可用、出色性能、可扩展、稳定和安全保障。 Nx02 漏洞描述 Ap…

vercel部署twikoo后评论收不到通知邮件问题解决方法

&#x1f4cc; 前言&#xff1a;本文主要是总结一下在vercel部署twikoo后收不到评论邮件通知问题的解决方法&#xff0c;本人在各种查资料无果后最终去twioo的git官方项目的issue中找到某位大佬给出的原因以及解决方案&#xff0c;故做此记录&#xff0c;希望对遇到此问题的同学…

重学JavaScript高级(八):ES6-ES12新增特性学习

ES6-ES12新增特性学习 ES6–对象字面量增强 属性的简写方法的简写计算属性名 let name "zhangcheng" //我想让sum作为obj的key值 let objKey "sum" let obj {//属性名的简写name//等同于name:name//方法的简写running(){}//等同于running:function()…

ERD助力研发资产沉淀研发提效

一、从痛点中思考答案 痛点一&#xff1a;复杂系统的设计和逻辑碎片化散落&#xff0c;缺少沉淀导致系统后期维护、迭代以及架构升级都非常困难。 痛点二&#xff1a;由于新需求或新项目导致的系统的老旧逻辑梳理往往耗费大量人力&#xff0c;甚至造成人才的流失。 痛点三&a…

React 入门 - 05(响应式与事件绑定)

本章内容 目录 一、响应式设计思想二、React 中的事件绑定 继上一节我们简单实现一个 TodoList来更加了解编写组件的一些细节。本节继续这个案例功能的完成。 一、响应式设计思想 1、在原生的 JS中&#xff0c;如果要实现点击”提交“按钮就将输入框的内容添加至页面列表中&…

什么是协议和什么是OSI模型,以及两者之间的关系

目录 协议 1.协议 2.OSI模型 &#xff08;1&#xff09;什么是OSI模型 &#xff08;2&#xff09;OSI模型和协议之间的关系 总结 &#xff08;3&#xff09;示意图 协议 1.协议 就是双方通过协商&#xff0c;需要共同遵守的约定 协议就是规则&#xff0c;是约定 http…

数字战场上的坚固屏障:雷池社区版(WAF)

黑客的挑战 智能语义分析算法&#xff1a; 黑客们常利用复杂技术进行攻击&#xff0c;但雷池社区版的智能语义分析算法能深入解析攻击本质&#xff0c;即使是最复杂的攻击手法也难以逃脱。 0day攻击防御&#xff1a; 传统防火墙难以防御未知攻击&#xff0c;但雷池社区版能有效…

Spark八:Spark性能优化

Spark性能调优 Spark调优的方法&#xff0c;包括RDD使用、文件读取&#xff0c;partition 学习资料&#xff1a;https://mp.weixin.qq.com/s/caCk3mM5iXy0FaXCLkDwYQ 一、Spark调优之RDD算子调优 1.1 RDD复用 在对RDD进行计算时&#xff0c;要避免相同的算子和计算逻辑下对…