首页 > 其他分享 >【架构】架构到底是是什么

【架构】架构到底是是什么

时间:2022-11-01 15:00:47浏览次数:70  
标签:架构 到底 什么 系统 MVC 模块 组件 子系统

对于技术人员来说,「架构」是一个再常见不过的词了。我们会对新员工培训整个系统的架构,参加架构设计评审,学习业界开源系统(例如,MySQLHadoop)的架构,研究大公司的架构实现,例如,微信架构、淘宝架构……虽然「架构」这个词常见,但如果深究一下「架构」到底指什么,大部分人也许并不一定能够准确地回答。例如:

  • 架构和框架是什么关系?有什么区别?
  • Linux有架构,MySQL有架构,JVM也有架构,使用Java开发、MySQL存储、跑在Linux上的业务系统也有架构,应该关注哪个架构呢?
  • 微信有架构,微信的登录系统也有架构,微信的支付系统也有架构,当我们谈微信架构时,到底是在谈什么架构?

要想准确地回答这几个问题,关键在于梳理几个有关系而又相似的概念,包括:系统与子系统、模块与组件、框架与架构。

系统与子系统

我们先来看维基百科定义的「系统」。

系统泛指由一群有关联的个体组成,根据某种规则运作,能完成个别元件不能单独完成的工作的群体。它的意思是「总体」「整体」或「联盟」。

我来提炼一下里面的关键内容:

  1. 关联:系统是由一群有关联的个体组成的,没有关联的个体堆在一起不能成为一个系统。例如,把一个发动机和一台PC放在一起不能称之为一个系统,把发动机、底盘、轮胎、车架组合起来才能成为一台汽车。
  2. 规则:系统内的个体需要按照指定的规则运作,而不是单个个体各自为政。规则规定了系统内个体分工和协作的方式。例如,汽车发动机负责产生动力,然后通过变速器和传动轴,将动力输出到车轮上,从而驱动汽车前进。
  3. 能力:系统能力与个体能力有本质的差别,系统能力不是个体能力之和,而是产生了新的能力。例如,汽车能够载重前进,而发动机、变速器、传动轴、车轮本身都不具备这样的能力。

我们再来看子系统的定义。

子系统也是由一群有关联的个体所组成的系统,多半会是更大系统中的一部分。

其实子系统的定义和系统定义是一样的,只是观察的角度有差异,一个系统可能是另外一个更大系统的子系统。

按照这个定义,系统和子系统比较容易理解。我们以微信为例来做一个分析。

  1. 微信本身是一个系统,包含聊天、登录、支付、朋友圈等子系统。
  2. 朋友圈这个系统又包括动态、评论、点赞等子系统。
  3. 评论这个系统可能又包括防刷子系统、审核子系统、发布子系统、存储子系统。
  4. 评论审核子系统不再包含业务意义上的子系统,而是包括各个模块或者组件,这些模块或者组件本身也是另外一个维度上的系统。例如,MySQLRedis等是存储系统,但不是业务子系统。

模块与组件

模块和组件两个概念在实际工作中很容易混淆,我们经常能够听到类似这样的说法:

  • MySQL模块主要负责存储数据,而ElasticSearch模块主要负责数据搜索。
  • 我们有安全加密组件、有审核组件。
  • App的下载模块使用了第三方的组件。

造成这种现象的主要原因是,模块与组件的定义并不好理解,也不能很好地进行区分。我们来看看这两者在维基百科上的定义。

软件模块(Module)是一套一致而互相有紧密关连的软件组织。它分别包含了程序和数据结构两部分。现代软件开发往往利用模块作为合成的单位。模块的接口表达了由该模块提供的功能和调用它时所需的元素。模块是可能分开被编写的单位。这使它们可再用和允许人员同时协作、编写及研究不同的模块。

软件组件定义为自包含的、可编程的、可重用的、与语言无关的软件单元,软件组件可以很容易被用于组装应用程序中。

可能你看完这两个定义后一头雾水,还是不知道这两者有什么区别。造成这种现象的根本原因是,模块和组件都是系统的组成部分,只是从不同的角度拆分系统而已

从逻辑的角度来拆分系统后,得到的单元就是模块」;从物理的角度来拆分系统后,得到的单元就是「组件」。划分模块的主要目的是职责分离;划分组件的主要目的是单元复用。其实,「组件」的英文component也可翻译成中文的「零件」一词,「零件」更容易理解一些,「零件」是一个物理的概念,并且具备「独立且可替换」的特点。

我以一个最简单的网站系统来为例。假设我们要做一个学生信息管理系统,这个系统从逻辑的角度来拆分,可以分为登录注册模块、个人信息模块、个人成绩模块;从物理的角度来拆分,可以拆分为NginxWeb服务器、MySQL

框架与架构

框架是和架构比较相似的概念,且两者有较强的关联关系,所以在实际工作中,这两个概念有时我们容易分不清楚。参考维基百科上框架与架构的定义,我来解释两者的区别。

软件框架(Software framework)通常指的是为了实现某个业界标准或完成特定基本任务的软件组件规范,也指为了实现某个软件组件规范时,提供规范所要求之基础功能的软件产品。

我来提炼一下其中关键部分:

  1. 框架是组件规范:例如,MVC就是一种最常见的开发规范,类似的还有MVPMVVMJ2EE等框架。
  2. 框架提供基础功能的产品:例如,Spring MVCMVC的开发框架,除了满足MVC的规范,Spring提供了很多基础功能来帮助我们实现功能,包括注解(@Controller等)、Spring SecuritySpring JPA等很多基础功能。

软件架构指软件系统的「基础结构」,创造这些基础结构的准则,以及对这些结构的描述。

单纯从定义的角度来看,框架和架构的区别还是比较明显的,框架关注的是「规范」,架构关注的是「结构」。框架的英文是Framework,架构的英文是ArchitectureSpring MVC的英文文档标题就是Web MVC framework

虽然如此,在实际工作中我们却经常碰到一些似是而非的说法。例如,我们的系统是MVC架构、我们需要将android app重构为MVP架构、我们的系统基于SSH框架开发、我们是SSH的架构、某系统是基于Spring MVC框架开发,标准的MVC架构……

究竟什么说法是对的,什么说法是错的呢?

其实这些说法都是对的,造成这种现象的根本原因隐藏于架构的定义中,关键就是「基础结构」这个概念并没有明确说是从什么角度来分解的。采用不同的角度或者维度,可以将系统划分为不同的结构,其实我在「模块与组件」中的学生管理系统示例已经包含了这点。

从业务逻辑的角度分解,学生管理系统的架构是:

从物理部署的角度分解,学生管理系统的架构是:

从开发规范的角度分解,学生管理系统可以采用标准的MVC框架来开发,因此架构又变成了MVC架构:

这些「架构」,都是学生管理系统正确的架构,只是从不同的角度来分解而已,这也是IBMRUP将软件架构视图分为著名的「4+1视图」的原因。

重新定义架构

参考维基百科的定义,我将架构重新定义为:软件架构指软件系统的顶层结构

这个定义看似很简单,但包含的信息很丰富,基本上把系统、子系统、模块、组件、架构等概念都串起来了,我来详细解释一下。

首先,系统是一群关联个体组成,这些「个体」可以是「子系统」、「模块」、「组件」等;架构需要明确系统包含哪些「个体」。

其次,系统中的个体需要「根据某种规则」运作,架构需要明确个体运作和协作的规则。

第三,维基百科定义的架构用到了「基础结构」这个说法,我改为「顶层结构」,可以更好地区分系统和子系统,避免将系统架构和子系统架构混淆在一起导致架构层次混乱。

最后补充下思维导图:

标签:架构,到底,什么,系统,MVC,模块,组件,子系统
From: https://www.cnblogs.com/xhb-bky-blog/p/16846825.html

相关文章

  • 为什么选择高防DNS云解析?(一)-中科三方
    DNS(domainnameserver, 域名服务器)是互联网的一项核心服务,是进行域名与之对应的IP地址之间转换的系统,可将易于记忆的域名转换为方便服务器识别的用于互连通信的数字IP地......
  • 游戏服务器架构:如何避免缓存积累延迟
    不管使用TCP还是KCP,你都不可能超越信道限制的发送数据。TCP的发送窗口SNDBUF决定了最多可以同时发送多少数据,KCP的也一样。当前发送且没有得到ACK/UNA确认的数据,都会......
  • 游戏服务器架构:经典的全服分线模型概述
    全服分线模型一.模型描述由于多进程服务器模型的发展,游戏开发者们首先发现,由于游戏业务的特点,那些需要持久化的数据,一般都是玩家的存档,以及一些游戏本身需要用的,在运行期只......
  • 游戏服务器架构:有状态和无状态服务器
    简介对服务器程序来说,究竟是有状态服务,还是无状态服务,其判断依旧——两个来自相同发起者的请求在服务器端是否具备上下文关系。状态化请求,服务器端一般都要保存请求的相关信......
  • 游戏服务器架构:使用KCP 加速游戏消息,让全球玩家流畅联网
    定义      kcp协议是传输层的一个具有可靠性的传输层ARQ协议。     它的设计是为了解决在网络拥堵情况下tcp协议的网络速度慢的问题。     ......
  • C语言: ---Linux下ulimit是什么鬼
        其实ulimit的讲解不属于C或者C++语言范畴,他只是在我们日常开发或者线上linux运行环境不可缺少的工具。    比如我们要查看服务器崩溃的core文件,允许core......
  • 利息被银行四舍五入后,你到底是赚了还是亏了?
    利息被银行四舍五入后,你到底是赚了还是亏了?答案和想的不太一样播报文章新浪财经发布时间:2020-07-1119:55新浪财经官方账号,优质财经领域创作者关注来......
  • 企业数字化转型到底是什么?
    企业数字化就是要构建“业务数字化、数字资产化、资产服务化、服务业务化”闭环,通过数字化技术能力反哺业务,所以它不是做信息化,而是业务层面的转型,是一把手工程,数字化强调的......
  • ERP 系统的核心思想和主要作用有什么?
    ERP系统的核心思想就是用规范化、标准化的管理来提高企业经营效益,充分整合、调配、调动企业内物质资源、资金资源和信息资源等各项资源,重点针对物资资源管理(物流)、人力资源......
  • 为什么mysql单表行数建议不要超过2000w?
    mysql使用innodb的B+树存储表项,保存在.ibd文件中,其中叶子节点页存储数据页,非叶子节点页存储索引页.ibd文件的一页大小16kb,其中有15kb存记录。假设每页的记录都存满一页:1.非......