一篇文章掌握系统架构的演变和常见微服务框架

news2025/1/23 2:00:18

目录

前言

一、系统架构的演变

1、单体应用架构

优点:

缺点:

2、垂直应用架构

优点:

缺点:

3、分布式SOA架构

3.1 什么是SOA

3.2 SOA架构

优点:

缺点:

4、微服务架构

优点:

缺点:

5、SOA与微服务的关系

SOA( Service Oriented Architecture )

微服务架构

二、常见微服务框架

1、Spring Cloud

1.1 主要功能

1.2 主要组件

2、Spring Cloud Alibaba

2.1 主要功能

2.2 主要组件

三、总结


前言

随着互联网的发展,网站应用的规模不断扩大,常规的应用架构已无法应对分布式服务架构以及

微服务架构势在必行,急需一个治理系统确保架构有条不紊的演进。

一、系统架构的演变

1、单体应用架构

Web应用程序发展的早期,大部分web工程(包含前端页面,web层代码,service层代码,dao层代码)是将所有的功能模块,打包到一起并放在一个web容器中运行

比如搭建一个电商系统:客户下订单,商品展示,用户管理。这种将所有功能都部署在一个web容器中运行的系统就叫做单体架构

优点:

  • 所有的功能集成在一个项目工程中

  • 项目架构简单,前期开发成本低,周期短小型项目的首选

缺点:

  • 全部功能集成在一个工程中,对于大型项目不易开发、扩展及维护

  • 系统性能扩展只能通过扩展集群结点,成本高、有瓶颈

  • 技术栈受限

2、垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。

优点:
  • 项目架构简单,前期开发成本低,周期短小型项目的首选

  • 通过垂直拆分,原来的单体项目不至于无限扩大。

  • 不同的项目可采用不同的技术

缺点:
  • 全部功能集成在一个工程中,对于大型项目不易开发、扩展及维护

  • 系统性能扩展只能通过扩展集群结点,成本高、有瓶颈

3、分布式SOA架构

3.1 什么是SOA

SOA 全称为 Service-Oriented Architecture,即面向服务的架构。它可以根据需求通过网络对松散耦合的粗粒度应用组件(服务)进行分布式部署、组合和使用。一个服务通常以独立的形式存在于操作系统进程中。

站在功能的角度,把业务逻辑抽象成可复用、可组装的服务,通过服务的编排实现业务的快速再生,目的:把原先固有的业务功能转变为通用的业务服务,实现业务逻辑的快速复用。

通过上面的描述可以发现 SOA 有如下几个特点:分布式、可重用、扩展灵活、松耦合。

3.2 SOA架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。

优点:
  • 抽取公共的功能为服务,提高开发效率

  • 对不同的服务进行集群化部署,解决系统压力。

  • 基于ESB/Dubbo减少系统耦合。

缺点:
  • 抽取服务的粒度较大

  • 服务提供方与调用方,接口耦合度较高。

4、微服务架构

优点:
  • 通过服务的原子化拆分,以及微服务的独立打包、部署和升级小团队的交付周期将缩短,运维成本也将大幅度下降。

  • 微服务遵循单一原则。微服务之间采用Restful等轻量协议传输。

缺点:
  • 微服务过多服务治理成本高不利于系统维护。

  • 分布式系统开发的技术成本高(容错、分布式事务等)。

5、SOA与微服务的关系

SOA( Service Oriented Architecture )

面向服务的架构”:他是一种设计方法,其中包含多个服务, 服务之间通过相互依赖最终提供一系

列的功能。

一个服务,通常以独立的形式存在与操作系统进程中,各个服务之间通过网络调用。

微服务架构

其实和 SOA 架构类似,微服务是在 SOA 上做的升华,微服务架构强调的一个重点是“业务需要彻

底的组件化和服务化”,原有的单个业务系统会拆分为多个可以独立开发、设计、运行的小应用。

这些小应用之间通过服务完成交互和集成。

功能SOA微服务
组件大小大块业务逻辑单独任务或小块业务逻辑
耦合度通常松耦合总是松耦合
公司架构任何类型小型、专注于功能交叉团队
管理着重中央管理着重分散管理
目标确保应用能够交互操作执行新功能、快速拓展开发团队

二、常见微服务框架

1、Spring Cloud

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统

基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可

以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud并没有重复制造轮子,它只是将

目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行

再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分

布式系统开发工具包。

SpringCloud, 基于SpringBoot提供了一套微服务解决方案,包括服务注册与发现,配置中心,

全链路监控,服务网关,负载均衡,熔断器等组件,除了基于NetFlix的开源组件做高度抽象封装之

外,还有一些选型中立的开源组件

SpringCloud是目前国内使用最广泛的微服务框架

官网地址:https://spring.io/projects/spring-cloud

SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了这些组件的自动装配,从而

供了良好的开箱即用体验。

Spring Cloud Netflix,主要由:EurekaRibbonFeignHystrixZuul|GatewayConfig等组件组成。

1.1 主要功能

  1. 服务注册与发现:Spring Cloud Eureka可以实现服务的注册与发现,使得服务之间可以方便地进行通信和调用。

  2. 负载均衡:Spring Cloud Ribbon提供了负载均衡的功能,可以根据配置的负载均衡策略将请求分发到不同的服务实例上。

  3. 服务调用:Spring Cloud Feign可以简化服务之间的调用,通过声明式的方式定义服务接口,实现服务之间的远程调用。

  4. 服务容错:Spring Cloud Hystrix提供了服务容错的功能,可以实现服务的降级、熔断和限流,保证系统的稳定性和可靠性。

  5. 配置管理:Spring Cloud Config可以集中管理应用程序的配置,支持动态刷新配置,方便应用程序的部署和管理。

  6. 服务网关:Spring Cloud Gateway提供了统一的API网关,可以对外暴露统一的接口,并提供路由、过滤和限流等功能。

  7. 消息总线:Spring Cloud Bus可以实现消息总线的功能,方便在分布式系统中传播状态变化和配置变更。

  8. 分布式追踪:Spring Cloud Sleuth可以实现分布式系统的请求追踪和日志聚合,方便排查和解决问题。

  9. 监控聚合:使用 Hystrix 监控,我们需要打开每一个服务实例的监控信息来查看。而 Turbine 可以帮助我们把所有的服务实例的监控信息聚合到一个地方统一查看。

1.2 主要组件

  1. Netflix Eureka:服务的注册与发现(注册中心)。

    Eureka就是用来管理微服务的通信地址清单的,有了Eureka之后我们通过服务的名字就能实现服务的调用。

  2. Netflix Ribbon:客户端负载均衡,主要负责负载均衡,针对每次请求,Ribbon会从Euraka client服务列表中选择一个服务发起请求,均匀的把请求分发到各个服务中。

  3. Netflix Feign:服务接口调用, Feign是一个声明式 REST 客户端,主要是为了简便服务调用,更快捷、优雅地调用 HTTP API。主要是实现原理是用动态代理。

    Ribbon和Feign都是客户端负载均衡器,它的作用是在服务发生调用的时候帮我们将请求按照某种规则分发到

    多个目标服务器上,简单理解就是用来解决微服务之间的通信问题。

  4. Spring Cloud Config:分布式配置

    分布式配置管理中心,用来统一的管理服务的配置文件,运行期间动态调整配置,不再需要在每个服务部署的机器上编写配置文件,服务会向配置中心统一拉取自己的配置。

  5. Netflix Zuul:服务网关

    我们可以把它看作是微服务的大门,所有的请求都需要经过zuul之后才能到达目标服务,根据这一特性,我们

    可以把微服务公共的是事情交给zuul统一处理。

  6. Netflix Hystrix:断路器

    Hystrix是用来解决微服务故障,保护微服务安全的组件,避免因为服务器故障,导致整个调用链上的微服务

    全都出现异常。

  7. Spring Cloud Bus:消息总线

    消息总线是在微服务中给各个微服务广播消息的一个组件,我们使用消息总线构建一个消息中心,其他微服务

    来接入到消息中心,当消息总线发起消息,接入的微服务都可以收到消息从而进行消费。

  8. Spring Cloud Sleuth:微服务链路追踪。

    链路追踪的作用就是来监控维护之间的调用关系,让程序员方便直观的感受到一个请求经历了哪些微服务,以

    及服务的请求时间,是否有异常等。

  9. Netflix Turbine:聚合Hystrix监控数据,监控聚合,使用 Hystrix 监控,我们需要打开每一个服务实例的监

    控信息来查看。而 Turbine 可以帮助我们把所有的服务实例的监控信息聚合到一个地方统一查看。

2、Spring Cloud Alibaba

Spring Cloud Alibaba 致力于提供微服务开发一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者通过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。

依托 Spring Cloud Alibaba,你只需要添加一些注解和少量配置,就可以将 Spring Cloud 应用接入阿里微服务解决方案通过阿里中间件来迅速搭建分布式应用系统。

Spring Cloud Alibaba,主要由:NacosSentinelSeata等组件组成。

2.1 主要功能

  1. 服务限流降级 :默认支持 WebServlet、WebFlux, OpenFeign、RestTemplate、Spring Cloud Gateway, Zuul, Dubbo 和 RocketMQ 限流降级功能的接入,可以在运行时通过控制台实时修改限流降级规则,还支持查看限流降级 Metrics 监控。

  2. 服务注册与发现 :适配 Spring Cloud 服务注册与发现标准,默认集成了 Ribbon 的支持。

  3. 分布式配置管理 :支持分布式系统中的外部化配置,配置更改时自动刷新。

  4. 消息驱动能力 :基于 Spring Cloud Stream 为微服务应用构建消息驱动能力。

  5. 分布式事务 :使用 @GlobalTransactional 注解, 高效并且对业务零侵入地解决分布式事务问题。

  6. 阿里云对象存储 :阿里云提供的海量、安全、低成本、高可靠的云存储服务。支持在任何应用、任何时间、任何地点存储和访问任意类型的数据。

  7. 分布式任务调度 :提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。同时提供分

  8. 布式的任务执行模型,如网格任务。网格任务支持海量子任务均匀分配到所有 Worker(schedulerx-client)上执行。

  9. 阿里云短信服务 :覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。

2.2 主要组件

  1. Sentinel:阿里巴巴源产品,把流量作为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。

  2. Nacos:一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

  3. RocketMQ:一款开源的分布式消息系统,基于高可用分布式集群技术,提供低延时的、高可靠的消息发布与订阅服务。

  4. Dubbo:Apache Dubbo™ 是一款高性能 Java RPC 框架。

  5. Seata:阿里巴巴开源产品,一个易于使用的高性能微服务分布式事务解决方案。

  6. Alibaba Cloud OSS : 阿里云对象存储服务(Object Storage Service,简称 OSS),是阿里云提供的海量、安全、低成本、高可靠的云存储服务。您可以在任何应用、任何时间、任何地点存储和访问任意类型的数据。

  7. Alibaba Cloud SchedulerX: 阿里中间件团队开发的一款分布式任务调度产品,提供秒级、精准、高可靠、高可用的定时(基于 Cron 表达式)任务调度服务。

  8. Alibaba Cloud SMS: 覆盖全球的短信服务,友好、高效、智能的互联化通讯能力,帮助企业迅速搭建客户触达通道。

三、总结

随着互联网的发展,网站应用的规模不断扩大,常规的应用架构已无法应对分布式服务架构以及

微服务架构势在必行,急需一个治理系统确保架构有条不紊的演进。


系统架构的演变:1、单体应用架构。2、垂直应用架构。3、分布式SOA架构。4、微服务架构

常见微服务框架有Spring Cloud、Spring Cloud Alibaba

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

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

相关文章

os-ten-ta-tion

在线词源词典 这是一张展现英语发展轨迹的地图。词源不是定义,但词源解释了我们现在所使用的单词,在过去的 600 年甚至 2000 年前的意思和发音是怎样的。 正文中的日期表示该单词最早留下文献记录的年份(除非另有说明,一般指英文文献)。但这…

【解决】电脑上的WIFI图标不见了咋整?

相信不少同学都遇到过这种情况:电脑上的wifi图标莫名不见了,甚至有时候还是在使用的中途突然断网消失的。 遇到这种情况一般有两种解决方案: 1. 在开机状态下长按电源键30秒以上 这种办法应该是给主板放电,一般应用在wifi6上面。…

Vue3-32-路由-重定向路由

什么是重定向 路由的重定向 :将匹配到的路由 【替换】 为另一个路由。 redirect : 重定向的关键字。 重定向的特点 1、重定向是路由的直接替换,路由的地址是直接改变的; 2、在没有子路由配置的情况下,重定向的路由可以省略 component 属性的配…

HackTheBox - Medium - Linux - Investigation

Investigation Investigation 是一款 Linux 机器,难度为中等,它具有一个 Web 应用程序,可为图像文件的数字取证分析提供服务。服务器利用 ExifTool 实用程序来分析图像,但是,正在使用的版本存在命令注入漏洞&#xff…

带大家做一个,易上手的家常糖醋白菜

准备 如果是大白菜就一个 小白菜就要两个 因为白菜炒完之后会变少 将白菜叶剥开每叶分成三个小块 整个剥完之后 放入盆中清洗干净 调一个糖醋汁 一勺料酒 两勺生抽 三勺白砂糖 四勺香醋 起锅烧油 放两个干辣椒 辣椒炒一下 然后倒入白菜 翻炒直到油全部融入白菜 然后倒入…

python打开文件的方式比较

open(addr,w) 打开之后文件无论以前有什么,打开后都要清空 /// open(addr,r) 文件打开后,不删除以前内容

fineBI web组件传参

1、fineBI web组件传参 1.1、 Web组件- FineBI帮助文档 FineBI帮助文档1. 概述1.1 版本FineBI 版本HTML5移动端展现功能变动6.0--V11.0.83web组件适配移动端效果优化6.0.13-web组件支持传递参数 ${过滤组件https://help.fanruan.com/finebi/doc-view-143.html 1.2、自己做的例…

51单片机之LED灯

51单片机之LED灯 🌴前言:🏮点亮LED灯的原理💘点亮你的第一个LED灯💘点亮你的八个LED灯 📌让LED灯闪烁的原理🎽 LED灯的闪烁🏓错误示范1🏓正确的LED闪烁代码应该是这样&am…

太阳系三体模拟器

介绍 《三体》是刘慈欣创作的长篇科幻小说,文中提到的三体问题比较复杂和无解。 该项目代码就是利用 Python 来模拟三体的运行,此项目代码完全共享,欢迎下载。 我们可以自己通过调整天体的初始坐标、质量和矢量速度等等参数来自定义各种场景…

2024年01月数据库流行度最新排名

点击查看最新数据库流行度最新排名(每月更新) 2024年01月数据库流行度最新排名 TOP DB顶级数据库索引是通过分析在谷歌上搜索数据库名称的频率来创建的 一个数据库被搜索的次数越多,这个数据库就被认为越受欢迎。这是一个领先指标。原始数…

【算法每日一练]-数论 (保姆级教程 篇2 )#行列式 #甜甜花研究 #约数个数 #模数 #数树 #盒子与球

目录 今日知识点: 辗转相减法化下三角求行列式 组合数动态规划打表 约数个数等于质因数的次方1的乘积 求一个模数 将n个不同的球放入r个不同的盒子:f[i][j]f[i-1][j-1]f[i-1][j]*j 行列式 甜甜花的研究 约数个数 模数 数树 盒子与球 行列…

【刷题日志】深度理解除(/)与取模(%)附水仙花数以及变种水仙花数题解

文章目录 🚀前言🚀除与取模🚀水仙花数🚀变种水仙花数 🚀前言 本专栏文章都直奔刷题主题,阿辉都不会在废话了,加油,少年!!! 🚀除与取…

《MySQL系列-InnoDB引擎03》MySQL文件相关介绍

文章目录 第三章 文件1 参数文件1.1 什么是参数?1.2 参数类型 2 日志文件2.1 错误日志2.2 慢查询日志2.2x 慢查询日志拓展-如何开启MySQL慢查询日志?2.2XX 慢查询日志拓展-mysqldumpslow日志分析工具2.3 查询日志2.4 二进制日志 3 套接字文件4 PID文件5 …

使用ros2 launch启动gazebo时,可以设置的sdf文件名称

事实证明:这个文件夹里面的名称都可以设置/usr/share/gz/gz-sim8/worlds 并且不用指定文件夹路径,可以直接输入文件名。当然也可以完全指定路径:

梳理Langchain-Chatchat-UI接口文档

在 Langchain-Chatchat v0.1.17 版本及以前是有前后端分离的 Vue 项目的,但是 v0.2.0 后就没有了。所以本文使用的是 Langchain-Chatchat v0.1.17 版本中的 Vue 项目。经过一番折腾终于将 Langchain-Chatchat v0.1.17 版本前端 Vue 接口和 Langchain-Chatchat v0.2.…

使用MQTT.JS创建一个网页版的MQTT客户端

一、MQTT.JS介绍 MQTT.js 是一个开源的 MQTT 协议的客户端库,使用 JavaScript 编写,主要用于 Node.js 和 浏览器环境中。是JavaScript 环境下的 MQTT 客户端库。可以用于微信小程序、支付宝小程序等定制浏览器环境。 我们可以直接在HTML文件中进行调用…

计算字符串的长度几种方法 | 递归 | 指针减指针 | 计数器 | C语言 | 详解 | 期末考试必看!!!

一,使用 递归 计算 字符串 的 长度 1,题目描述 2,分析题目 Ⅰ,题目中要求除了函数的形参,函数中不能够使用多余的变量(这是比较苛刻的要求)。 Ⅱ,根据此,很自然的…

C++正则表达式全攻略:从基础到高级应用

C正则表达式全攻略:从基础到高级应用 一、基础知识二、正则表达式的基本匹配三、C中使用正则表达式四、高级正则表达式五、实践示例六、性能优化6.1、编译正则表达式6.2、避免过度使用回溯6.3、优化匹配算法 七、总结 一、基础知识 正则表达式是一种用于匹配、搜索…

C#【必备技能篇】cmd重定向

文章目录 一、实现目的二、工程1:Test.cs代码三、工程2:MainConsoleApp.cs代码四、测试结果 一、实现目的 通过MainConsoleApp.exe向Test.exe中输入参数,并将结果返回到MainConsoleApp.exe 二、工程1:Test.cs代码 using System…

机器学习-生存分析:如何基于随机生存森林训练乳腺癌风险评估模型?

一、 引言 乳腺癌是女性最常见的恶性肿瘤之一,也是全球范围内女性死亡率最高的癌症之一。据统计,每年全球有超过200万人被诊断为乳腺癌,其中约60万人死于该疾病。因此,乳腺癌的早期诊断和风险评估对于预防和治疗乳腺癌具有非常重要…