01 - 架构到底是指什么?.docx
《01 - 架构到底是指什么?.docx》由会员分享,可在线阅读,更多相关《01 - 架构到底是指什么?.docx(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、01 | 架构到底是指什么? 对于技术人员来说,架构是一个再常见不过的词了。我们会对新员工培训整个系统的架构,参与架构设计评审,学习业界开源系统(例如,MySQL、Hadoop)的架构,探讨大公司的架构实现(例如,微信架构、淘宝架构)……虽然架构这个词常见,但假如深究一下架构究竟指什么,大部分人或许并不肯定能够精确地回答。例如: 架构和框架是什么关系?有什么区分? Linux 有架构,MySQL 有架构,JVM 也有架构,运用 Java 开发、MySQL 存储、跑在 Linux 上的业务系统也有架构,应当关注哪个架构呢? 微信有架构,微信的登录系统也有架构,微信的支
2、付系统也有架构,当我们谈微信架构时,究竟是在谈什么架构? 要想精确地回答这几个问题,关键在于梳理几个有关系而又相像的概念,包括:系统与子系统、模块与组件、框架与架构。 系统与子系统 我们先来看维基百科定义的系统。 系统泛指由一群有关联的个体组成,依据某种规则运作,能完成个别元件不能单独完成的工作的群体。它的意思是总体整体或联盟。 我来提炼一下里面的关键内容: 关联:系统是由一群有关联的个体组成的,没有关联的个体堆在一起不能成为一个系统。例如,把一个发动机和一台 PC 放在一起不能称之为一个系统,把发动机、底盘、轮胎、车架组合起来才能成为一台汽车。 规则:系统内的个体须要根据指定的规则运作,而不
3、是单个个体各自为政。规则规定了系统内个体分工和协作的方式。例如,汽车发动机负责产生动力,然后通过变速器和传动轴,将动力输出到车轮上,从而驱动汽车前进。 实力:系统实力与个体实力有本质的差别,系统实力不是个体实力之和,而是产生了新的实力。例如,汽车能够载重前进,而发动机、变速器、传动轴、车轮本身都不具备这样的实力。 我们再来看子系统的定义。 子系统也是由一群有关联的个体所组成的系统,多半会是更大系统中的一部分。 其实子系统的定义和系统定义是一样的,只是视察的角度有差异,一个系统可能是另外一个更大系统的子系统。 根据这个定义,系统和子系统比较简单理解。我们以微信为例来做一个分析。 微信本身是一个系
4、统,包含闲聊、登录、支付、挚友圈等子系统。 挚友圈这个系统又包括动态、评论、点赞等子系统。 评论这个系统可能又包括防刷子系统、审核子系统、发布子系统、存储子系统。 评论审核子系统不再包含业务意义上的子系统,而是包括各个模块或者组件,这些模块或者组件本身也是另外一个维度上的系统。例如,MySQL、Redis 等是存储系统,但不是业务子系统。 模块与组件 模块和组件两个概念在实际工作中很简单混淆,我们常常能够听到类似这样的说法: MySQL 模块主要负责存储数据,而 ElasticSearch 模块主要负责数据搜寻。 我们有平安加密组件、有审核组件。 App 的下载模块运用了第三方的组件。 造成这
5、种现象的主要缘由是,模块与组件的定义并不好理解,也不能很好地进行区分。我们来看看这两者在维基百科上的定义。 软件模块(Module)是一套一样而相互有紧密关连的软件组织。它分别包含了程序和数据结构两部分。现代软件开发往往利用模块作为合成的单位。模块的接口表达了由该模块供应的功能和调用它时所需的元素。模块是可能分开被编写的单位。这使它们可再用和允许人员同时协作、编写及探讨不同的模块。 软件组件定义为自包含的、可编程的、可重用的、与语言无关的软件单元,软件组件可以很简单被用于组装应用程序中。 可能你看完这两个定义后一头雾水,还是不知道这两者有什么区分。造成这种现象的根本缘由是,模块和组件都是系统的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 01 架构到底是指什么? 架构 到底 什么
限制150内