“架构”到底指什么

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:
架构设计是技术人员成长和晋升过程中必须掌握的技能,虽然非常常见,但深究一下“架构”到底指什么,有多少人能够准确回答呢?
本文选自《从零开始学架构:照着做,你也能成为架构师》

对于技术人员来说,“架构”是一个再常见不过的词了:我们会给新员工介绍整个系统的架构,参加架构设计评审,学习业界开源系统(例如,MySQL、Hadoop)的架构,研究大公司的架构实现(例如,微信架构、淘宝架构)……虽然如此常见,但如果深究一下“架构”到底指什么,大部分人不一定能够准确地回答。例如: 
  • 架构和框架是什么关系?有什么区别? 
  • Linux有架构,MySQL有架构,JVM也有架构,使用Java开发、MySQL存储、跑在Linux上的业务系统也有架构,应该关注哪个架构呢? 
  • 微信有架构,微信的登录系统也有架构,微信的支付系统也有架构,当我们谈微信架构时,到底在谈什么架构? 
要想准确地回答以上问题,关键在于梳理几个有关系而又相似的概念,包括系统、子系统、模块、组件、框架和架构。

 系统与子系统

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

提炼维基百科定义的关键内容。 

(1)关联:系统是由一群有关联的个体组成的,没有关联的个体堆在一起不能成为一个系统。例如,把一个发动机和一台PC放在一起不能称之为一个系统,把发动机、底盘、轮胎、车架组合起来才能成为一台汽车。 

(2)规则:系统内的个体需要按照指定的规则运作,而不是单个个体各自为政。规则规定了系统内个体分工和协作的方式。例如,汽车发动机负责产生动力,然后通过变速器和传动轴,将动力输出到车轮上,从而驱动汽车前进。 

(3)能力:系统能力与个体能力有本质的差别,系统能力不是个体能力之和,而是产生了新的能力。例如,汽车能够载重前进,而发动机、变速器、传动轴、车轮本身都不具备这样的能力。 

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

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

按照这个定义,系统和子系统比较容易理解。我们以微信为例(以下内容仅仅是举例,微信不一定这么设计): 

(1)微信本身是一个系统,包含聊天、登录、支付、朋友圈等子系统。 

(2)朋友圈这个系统又包括动态、评论、点赞等子系统。 

(3)评论这个系统可能又包括防刷子系统、审核子系统、发布子系统、存储子系统。 

(4)评论审核子系统不再包含业务意义上的子系统,而是包括各个模块或组件,这些模块或组件本身也是另外一个维度上的系统。例如,MySQL、Redis等是存储系统,但不是业务子系统。 

以下是网上公开的微信朋友圈的架构示意图。

9cee95a9cfb7fb90998cb5a46bff3e9f170260bf

模块与组件

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

(1)MySQL模块主要负责存储数据,而Elasticsearch模块主要负责数据搜索。 

(2)我们有安全加密组件、有审核组件。 

(3)App的下载模块使用了第三方的组件。 

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

【模块】

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

【组件】

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

相信大部分人看完这两个定义还是一头雾水,看完也不知道到底两者有什么区别。造成这种现象的根本原因是模块和组件都是系统的组成部分,只是从不同的角度拆分系统而已。 从逻辑的角度来拆分后得到的单元就是“模块”,从物理的角度来拆分系统得到的单元就是“组件”;划分模块的主要目的是职责分离,划分组件的主要目的是单元复用。“组件”的英文单词component对应中文的“零件”一词,“零件”更容易理解一些,“零件”是一个物理的概念,并且具备“独立且可替换”的特点。 

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

框架与架构

框架是和架构比较相似的概念,且两者有较强的关联关系,所以在实际工作中,很多时候这两个概念并不是区分得很清楚。 

参考维基百科,框架的定义如下:

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

提炼维基百科定义的关键部分。 

(1)框架是组件规范。例如,MVC就是一种最常见的开发规范,类似的还有MVP、MVVM、J2EE等框架。 

(2)框架提供基础功能的产品。例如,Spring MVC是MVC的开发框架,除了满足MVC的规范,Spring提供了很多基础功能来帮助我们实现功能,包括注解(@Controller等)、Spring Security、Spring JPA等很多基础功能。 

参考维基百科,架构的定义如下(请搜索英文关键字Software Architecture,中文的词条解释很粗浅)。

Software architecture refers to the fundamental structures of a software system, the discipline of creating such structures, and the documentation of these structures. 

简单翻译一下:软件架构是指软件系统的“基础结构”,创造这些基础结构的准则,以及对这些结构的描述。 

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

虽然如此,在实际工作中我们却经常碰到一些似是而非的说法。例如,“我们的系统是MVC架构”,“我们需要将Android App重构为MVP架构”,“我们的系统基于SSH框架开发”,“我们是SSH的架构”,“XX系统是基于Spring MVC框架开发,标准的MVC架构”……究竟什么说法是对的,什么说法是错的呢? 

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

从业务逻辑的角度分解,“学生管理系统”的架构如下图所示。

1da04c151437d111e594064da0a3fd5c519de755

从物理部署的角度分解,“学生管理系统”的架构如下图所示。

989d2e4925107acf5d2934289af71f8e3a2072d9

从开发规范的角度分解,“学生管理系统”可以采用标准的MVC框架来开发,因此架构又变成了MVC架构,如下图所示。

b6ee64bf4d9e87ce6133bd22b51c8c74530fd084

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

重新定义架构

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

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

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

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

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

97bcdddc87f09b014bb639ea572f1037c5d93e1d
本文选自《从零开始学架构:照着做,你也能成为架构师》,作者李运华,电子工业出版社9月出版。

图书详情:https://u.jd.com/30ze9a

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
负载均衡 应用服务中间件 Linux
深入浅出学习透析Nginx服务器的架构分析及原理分析「底层技术原理+运作架构机制」
深入浅出学习透析Nginx服务器的架构分析及原理分析「底层技术原理+运作架构机制」
44 0
|
9月前
|
监控 安全 Java
高性能服务器设计思路和方案
高性能服务器设计思路和方案
79 0
|
存储 负载均衡 算法
作者推荐 | 【分布式技术专题】「架构设计方案」图解学习法总结集群模式下的各种软负载均衡策略实现及原理分析
作者推荐 | 【分布式技术专题】「架构设计方案」图解学习法总结集群模式下的各种软负载均衡策略实现及原理分析
141 0
作者推荐 | 【分布式技术专题】「架构设计方案」图解学习法总结集群模式下的各种软负载均衡策略实现及原理分析
|
10月前
|
存储 分布式计算 运维
大白话讲讲分布式存储系统的架构设计以及容错架构
分布式存储系统的架构设计旨在实现数据的分布式存储和负载均衡,通常采用数据分片和多节点存储的方式。容错架构则是为了提高系统的鲁棒性和可用性。在分布式存储系统中,容错架构常采用数据的冗余备份来应对节点故障或网络异常问题。通过复制数据到多个节点,即使某个节点发生故障,系统仍可以提供数据的可靠访问。此外,容错架构还包括故障检测和自动故障转移机制,用于及时检测节点故障,并将故障节点的任务转移给其他正常节点。这样可以保证系统在故障情况下仍能正常运行,并提供不间断的数据访问。通过合理的架构设计和有效的容错机制,分布式存储系统可以实现高可用性和数据可靠性,满足大规模数据存储和访问的需求。
621 0
大白话讲讲分布式存储系统的架构设计以及容错架构
|
12月前
|
存储 弹性计算 缓存
「分布式架构」“一切都是分布式”说最终一致性
「分布式架构」“一切都是分布式”说最终一致性
|
机器学习/深度学习 监控 Java
如何理解高性能服务器的高性能、高并发?
作为国内品牌服务器厂商,蓝海大脑液冷GPU服务器拥有大规模并行处理能力和无与伦比的灵活性。它主要用于为计算密集型应用程序提供足够的处理能力。GPU的优势在于可以由CPU运行应用程序代码,同时图形处理单元(GPU)可以处理大规模并行架构的计算密集型任务。GPU服务器是遥感测绘、医药研发、生命科学和高性能计算的理想选择。
如何理解高性能服务器的高性能、高并发?
|
存储 XML SQL
「数据密集型系统搭建」原理篇|用什么方式存储数据最合适
本篇来聊聊数据存储的内容,看看程序世界里数据是以什么形式存在的?为了描述数据并把它们和这个现实世界关联起来我们一般都是如何去进行表达的?最后通过我们习惯的表达方式再结合数据结构是如何存储下来的?   
186 0
「数据密集型系统搭建」原理篇|用什么方式存储数据最合适
|
存储 机器学习/深度学习 分布式计算
学习分布式存储应该从哪几方面着手?
学习分布式存储应该从哪几方面着手?
|
设计模式 负载均衡 并行计算
|
缓存 算法 NoSQL
何谓架构?
何谓架构? 前言 :在这个知识分享的爆炸时代,鉴于java生态的完整和繁荣,各种框架、中间件和工具包供我们使用。连新培训出来的人都知道ssm,微服务、集群、多线程、队列、高并发等技术,技术的间隔性正变得越来越小,仿佛
何谓架构?