【SpringCloud】概述 -- 微服务入门

在Java的整个学习过程中,大家势必会听见一些什么分布式-微服务、高并发、高可用这些专业术语,给人的感觉很高级,有一种高深莫测的感觉。可以看一下这篇博客对这些技术架构的演变有一个初步的认识:

服务端⾼并发分布式结构演进之路-CSDN博客文章浏览阅读950次,点赞11次,收藏9次。在进行技术学习过程中,由于大部分读者没有经历过一些中大型系统的实际经验,导致无法从服务端⾼并发分布式结构演进之路-----在进行技术学习过程中,由于大部分读者没有经历过一些中大型系统的实际经验,导致无法从全局理解一些概念,所以本文以一个"电子商务"应用为例,介绍从一百个到千万级并发情况下服务端的架构的演进过程,同时列举出每个演进阶段会遇到的相关技术,让大家对架构的演进有一个整体的认知,方便大家对后续知识做深入学习时有一定的整体视野。https://blog.csdn.net/qq_45875349/article/details/139639760?spm=1001.2014.3001.5501在学习Spring Cloud 之前,我们先来了解下什么是微服务,以及微服务的发展史.在架构发展的过程中,项目开发遇到了哪些问题,以及Spring Cloud是用来解决什么问题的,这些概念上的有助于对后续发开的深刻理解。其实在上面的博客中已经叙述了关于架构的发展过程。

1. 什么是微服务?

1.1 单体架构

对于一个系统来说,将前端+后端+数据库这些所有的业务都打包在一个项目中,就是单体架构。

比如大家都很熟悉的电商系统为例,电商系统包括:用户管理,商品管理,订单管理,支付管理,库存管理,物流管理等等,项目早期我们会把这些模块都写在一个web项目中,然后统一部署到一个Web服务器中。

这种架构开发简单,部署简单,一个项目就包含了所有的功能,省去了多个项目之间的交互和调用消耗
直接部署在一个服务器即可.

1.2 集群和分布式架构

当我们的系统服务的用户越来越多的时候,用户量逐渐增加、我们的服务面临的压力也逐渐增加。可能会面临一些问题:

  1. 后端服务器的压力就会越来越大,负载越来越高,甚至出现无法访问的情况
  2. 业务场景逐渐复杂.为了满足用户的需求,单体应用也会越来越大,各个业务代码之间的耦合度也会越来越高.任何一个问题,都需要整个项目重新构建,发布.
  3. 一个微小的问题,可能会导致整个应用挂掉

这时候我们一般会从两个角度进行优化:

1. 横向:添加服务器,把单台机器变成多台机器的集群。

2. 纵向:对应用的业务进行拆分,拆分为多个子项目。(垂直架构)

以单体结构规模的项目为单位进行垂直划分,也就是将一个大项目拆分成一个一个单体结构项目.项目和项目之间相对比较独立,接口多为数据同步功能.

集群

集群(cluster)是将一个系统完整的部署到多个服务器上,每个服务器都能提供系统的所有服务,多个
服务器通过负载均衡调度完成任务,每个服务器称为集群的节点(node)。

集群就像在一个大餐馆里设置了多个完全相同的厨房(节点)。每个厨房都可以独立处理整个菜单上的任何订单。顾客的订单被分配到不同的厨房,由每个厨房独立完成。这种方式确保如果一个厨房出了问题,其他厨房还能继续工作,保证餐馆整体的服务能力。

分布式

分布式是将一个系统拆分为多个子系统,多个子系统部署在多个服务器上,多个服务器上的子系统协同合作完成一个特定任务。

分布式则像是在一个大餐馆里,把菜单分成了多个部分,每个厨房只负责其中一部分。例如,一个厨房只做前菜,另一个厨房只做主菜,第三个厨房只做甜点。这样,每个厨房专注于自己负责的部分,所有厨房一起协作完成整个餐馆的服务。

集群和分布式区别和联系

1.从概念上.集群是多个计算机做同样的事,分布式是多个计算机做不同的事

2.从功能上.集群的每一个节点功能是相同的,并且可以替代的,分布式也是多个节点组成的系统,但是每个节点完成的业务是不同的,一个节点出现问题,这个业务就不可访问了

3.从关系上,分布式和集群在实践中,很多时候是互相配合使用的,比如分布式的某一个节点,可能由一个集群来代替,分布式架构大多是建立在集群上的,所以实际的分布式架构设计中并不会把分布式和集群单独区分,而是统称:分布式架构.

1.3 微服务架构

系统经过分布式进行业务拆分后,还会存在一些重复的功能开发。

在分布式架构下,当部署的服务越来越多,重复的代码就会越来越多,服务的调用关系也会越来越复杂,我们可以把一些通用的,会被多个上层服务调用的共享业务,提取成独立的基础服务,组成一个个微小的服务.这就是微服务.简单来说,微服务就是很小的服务.小到一个服务只对应一个单一的功能,只做一件事,这个服务可以单独部署运行

微服务之间可以采用REST和RPC协议进行通信,此处把他理解为接口的约定

从这个角度来看,微服务架构是分布式架构的一种拓展,这种架构模式下它拆分粒度更小,服务更独立,可以理解为:微服务是一种经过良好架构设计的分布式架构方案.

分布式架构侧重于压力的分散,强调的是服务的分散化.微服务侧重于能力的分散,更强调服务的专业化和精细分工.从实践的角度来看,微服务架构通常是分布式服务架构,反之则未必成立.所以,选择微服务通常意味着需要解决分布式架构的各种难题

2. 微服务的优势与挑战

微服务架构带来好处的同时,也面临着一些挑战,从单体服务转向微服务意味着管理更加复杂。

优势

  • 独立部署:每个服务可以独立部署和更新,不影响其他服务。这减少了发布的风险,提高了发布的灵活性。

  • 技术多样性:不同的服务可以使用不同的技术栈(编程语言、数据库等),根据具体需求选择最合适的技术。

  • 扩展性:可以针对某个服务单独进行水平扩展(增加实例数量)或垂直扩展(增加单个实例的处理能力),提高系统的弹性和资源利用率。

  • 容错性:服务之间的隔离性增强了系统的容错能力。如果一个服务失败,不会影响其他服务的运行,系统能更好地应对部分故障。

  • 团队独立性:不同的服务可以由不同的小团队负责,这样团队可以独立开发、测试和部署,提高开发效率和团队自主性。

  • 更容易的理解和维护:由于服务较小且专注于单一业务功能,代码库更易于理解和维护。新成员可以更快上手。

挑战

  • 分布式系统复杂性:微服务架构将单一应用分解成多个服务,带来了分布式系统的复杂性。服务间的通信、数据一致性、事务管理等都是新的挑战。

  • 服务间通信开销:服务间的网络通信会带来额外的开销,可能会影响性能。需要优化通信机制和策略,确保服务间通信高效可靠。

  • 数据管理:数据管理变得更加复杂。每个服务通常拥有自己的数据库,这导致分布式数据管理和跨服务的数据一致性变得困难。

  • 运维复杂性:管理和监控大量微服务实例需要更复杂的运维工具和流程。需要有效的监控、日志和告警系统来确保服务的稳定性。

  • 部署和版本控制:部署多个独立的服务需要有效的部署管道和版本控制机制,确保各服务之间的兼容性和协调。

  • 测试难度:测试微服务架构比测试单一应用复杂。需要模拟服务间的交互,并处理分布式环境下的各种测试场景。

  • 安全性:每个服务都是独立的潜在攻击点,需要确保每个服务的安全性,以及服务间通信的安全。

既然我们的java框架已经发展到这一步骤,并且已经出现了这些需求,就肯定需要解决这些困难,就算有困难也需要去使用微服务啊!我们是自己研发还是直接选取市场上比较成熟的技术来使用?

全球的互联网公司都在积极尝试自己的微服务落地方案.在Java领域,最引人注目的就是Spring Cloud。

3. 微服务解决方案:Spring Cloud

3.1 什么是Spring Cloud

Spring Cloud 提供了一些可以让开发人员快速构建分布式服务的工具,比如配置管理,服务发现,熔断,智能路由等.他们可以在任何分布式环境中很好的工作. Spring Cloud 通过集成和扩展多个开源项目,为开发人员提供了一整套解决方案,使他们能够快速构建和管理分布式服务。这些工具和库在任何分布式环境中都能很好地工作,帮助开发人员解决配置管理、服务发现、熔断、智能路由等常见问题,提高系统的稳定性、灵活性和可扩展性。

简单来说, Spring Cloud 就是分布式微服务架构的一站式解决方案,是微服务架构落地的多种技术的集合:

注意:

Spring Cloud 并不是Spring团队研发的框架,它只是把一些比较优秀的解决微服务架构中常见问题的开源框架基于SpringCloud规范进行了整合,并基于SpringBoot的风格,对这些组件进行封装,屏蔽掉了复杂的配置和实现原理,为开发者提供了开箱即用的微服务开发体验,这些开源技术的框架是由各个公司来维护的.Spring Cloud 就是这些微服务的大管家.

3.2 Spring Cloud版本

Spring Cloud中的所有子项目都依赖SpringBoot,所以SpringBoot和Spring Cloud的版本之间也存在-定的对应关系。⽐如SpringBoot 3.2.X对应的SpringCloud版本是2023.0.X

 3.3 Spring Cloud实现方案

在Spring Cloud的规范下,有很多实现,其中最为出名的是

  • Spring Cloud Netflix
  • Spring Cloud Alibaba

Spring Cloud Netflix

包含的组件及其主要功能大致如下:
Spring Cloud Netflix是 Netflix OSS(Netflix Open Source Software)在Spring Cloud规范下的实现.

  • Eureka:服务注册和发现
  • Zuul:服务网关
  • Ribbon:负载均衡
  • Feign: 服务调用组件
  • Hystrix: 断路器,提供服务熔断和限流
  • Hystrix Dashboard:监控面板
  • ...

在很长的一段时间里,Spring Cloud 一度被泛指 Spring Cloud Netflix.Spring Cloud一直以来把Netflix oss 套件作为其官方默认的一站式解决方案,然而,Netflix公司在2018年前后宣布其核心组件Hystrix、Ribbon、Zuul等均进入维护状态,Spring Cloud 也被迫宣布删除这些维护模块.

现在只有Eureka:服务注册和发现。

 Spring Cloud Netflix 在很多公司都有大规模使用,一旦停止更新,短期看影响不大,但长期显然是不合适的,Spring Cloud官方也提供了一些替换建议。

 Spring Cloud Alibaba

Spring Cloud Alibaba 是阿里巴巴集团下的开源组件和云产品在Spring Cloud规范下的实现

虽然Spring Cloud Alibaba目前并不是Spring Cloud官方推荐的默认方案,但是Spring Cloud Alibaba是阿里中间件团队主导的一个新生项目,正处于高速迭代中.甚至在Alibaba的开源组件还没有织入SpringCloud生态之前,就已经在各大公司广泛使用了.

官⽅⽹站: Spring Cloud Alibaba 是什么 | Spring Cloud Alibaba icon-default.png?t=N7T8https://sca.aliyun.com/docs/2022/overview/what-is-sca/如果说Spring Cloud Netflix是 Spring Cloud 的第一代实现,那么Spring Cloud Alibaba 也可以看做是Spring Cloud 的第二代实现,主要由 Nacos、Sentinel、Seata 等组件组成.

 Spring Cloud 实现对比

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java开源ERP系统Axelor汉化方法初探

Axelor简介 汉化过程介绍 定义语言和本地化 导出多语言记录 导入翻译 验证翻译 调整翻译 Axelor简介 2024年6月份Axelor ERP发布了8.1版本,适配JDK11及PostgreSQL12及以上版本(7及以前版本适配JDK8及PostgreSQL10)数据库。v8版本较之前…

kubernetes集群部署:node节点部署和cri-docker运行时安装(四)

安装前准备 同《kubernetes集群部署:环境准备及master节点部署(二)》 安装cri-docker 在 Kubernetes 1.20 版本之前,Docker 是 Kubernetes 默认的容器运行时。然而,Kubernetes 社区决定在 Kubernetes 1.20 及以后的…

昇思MindSpore学习入门-评价指标

当训练任务结束,常常需要评价函数(Metrics)来评估模型的好坏。不同的训练任务往往需要不同的Metrics函数。例如,对于二分类问题,常用的评价指标有precision(准确率)、recall(召回率&…

代码随想录算法训练Day58|LeetCode417-太平洋大西洋水流问题、LeetCode827-最大人工岛

太平洋大西洋水流问题 力扣417-太平洋大西洋水流问题 有一个 m n 的矩形岛屿,与 太平洋 和 大西洋 相邻。 “太平洋” 处于大陆的左边界和上边界,而 “大西洋” 处于大陆的右边界和下边界。 这个岛被分割成一个由若干方形单元格组成的网格。给定一个…

调度系统揭秘(下):调度算法与架构设计

文章目录 一、调度算法1.1、广度优先:1.2、深度优先1.3、总结广度优先搜索(BFS)深度优先搜索(DFS) 二、架构设计2.1、Master/Slave架构优劣分析 2.2、Leader架构优劣分析 2.3、总结 一、调度算法 在调度系统中,调度算…

【】AI八股-神经网络相关

Deep-Learning-Interview-Book/docs/深度学习.md at master amusi/Deep-Learning-Interview-Book GitHub 网上相关总结: 小菜鸡写一写基础深度学习的问题(复制大佬的,自己复习用) - 知乎 (zhihu.com) CV面试问题准备持续更新贴 …

本安防爆手机:危险环境下的安全通信解决方案

在石油化工、煤矿、天然气等危险环境中,通信安全是保障工作人员生命安全和生产顺利进行的关键。防爆智能手机作为专为这些环境设计的通信工具,提供了全方位的安全通信解决方案。 防爆设计与材料: 防爆智能手机采用特殊的防爆结构和材料&…

机械硬盘故障分析及损坏处理(坏道屏蔽)

机械硬盘故障分析: 1、加电后没有声音就是电机不转,是电路问题,更换电路板解决。 2、加电后电机转,有连续敲击声音,或有异响,磁头损坏或机械故障。 3、加电后电机转,运行正常,BIOS无…

建立数据通路(一)

指令周期(Instruction Cycle) 指令种类 Fetch(取得指令) 也就是从PC寄存器里找到对应的指令地址,根据指令地址从内存里把具体的指令,加载到指令寄存器中然后把PC寄存器自增,好在未来执行下一条指令 Decode(指令译码) 也就是根据指令寄存器里…

Apache Seata新特性支持 -- undo_log压缩

本文来自 Apache Seata官方文档,欢迎访问官网,查看更多深度文章。 本文来自 Apache Seata官方文档,欢迎访问官网,查看更多深度文章。 Apache Seata新特性支持 – undo_log压缩 Seata新特性支持 – undo_log压缩 现状 & 痛点…

类与对像(1)

好几个月没有写了,差了好多,这些天补回来吧。 接下来,让我们正式步入C与C语言开始不同的地方。 我对类的理解:类是对于具有相同或相似属性的数据集合。 类的关键词:class,public,protected&a…

2024年加密货币市场展望:L1、L2、LSD、Web3 和 GameFi 板块的全面分析与预测

随着区块链技术的快速发展,加密货币市场在2024年继续展现出蓬勃的生机和创新的潜力。本文将深入分析L1、L2、LSD、Web3和GameFi这五大板块的发展趋势和预测,帮助投资者和爱好者更好地理解和把握市场机遇。 一、L1:基础层协议的持续进化 L1&a…

python自动化办公之cryptography加密解密

目录 用到的库 实现效果 代码部分 1、加密2024.txt文件 2、解密2024.txt文件 用到的库 cryptography 实现效果 加密文件和解密文件 代码部分 1、加密2024.txt文件 # 加密 from cryptography.fernet import Fernet # 生成加密密钥 keyFernet.generate_key() cipher_s…

K8S 部署 EFK

安装说明 系统版本为 Centos7.9 内核版本为 6.3.5-1.el7 K8S版本为 v1.26.14 ES官网 开始安装 本次安装使用官方ECK方式部署 EFK,部署的是当前的最新版本。 在 Kubernetes 集群中部署 ECK 安装自定义资源 如果能打开这个网址的话直接用这个命令安装,打不开的话…

创建一个不带框架的javaweb工程

点击新建 选择Maven,然后在Archetype里面选择 webapp选项(注意这里需要配置好Maven的环境 如果没配好Maven引入依赖的时候会引不进来) 如果Maven配置之后就会显示配置成功 然后我们要配置tomacat的依赖 jde选择默认 然后点击部署 选择工件&a…

高阶算法班从入门到精通之路课程

本课程旨在帮助学员深入理解算法与数据结构的核心概念,从而掌握高级算法设计与分析技能。每集课程内容精心设计,涵盖了常用数据结构、经典算法及其应用场景等方面的深度讲解,同时通过大量实例演练,帮助学员提升解决实际编程难题的…

2000-2022年地级市数字经济指数(含控制变量)

2000-2022年地级市数字经济指数(含控制变量) 目录 数字经济对区域经济发展的影响实证研究 一、引言 二、文献综述 三、数据来源与变量说明 四、实证模型 五、程序代码与运行结果 数字经济对区域经济发展的影响实证研究 摘要: 本文旨在…

【分布式计算框架 MapReduce】高级编程—搜索日志数据分析

目录 一、对于 sogou_500w_utf 数据,使用 MapReduce 编程模型完成对以下数据的分析任务 1. 统计 2011-12-30 日搜索记录,每个时间段的搜索次数 (1)运行截图 (2) 源代码 2. 统计 2011-12-30 日 3 点至 …

C++类与对象

1. stack声明与定义 引入构造器实现 自定义 栈大小 // constructor构造器 // 1. 与类名相同,无返回值,被系统生成对象时自动调用,用于初始化 // 2. 可以有参数,构造器的重载,默认参数,重载和默认参数不同…

2024阿里国际春招笔试

第一题 0 解题思路: 数据范围很大,肯定得找规律。 当n1时,0,1,结果为0 当n2时,00,01,10,11,结果为1 当n3时,000,001,010&a…