欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    01 - 架构到底是指什么?.docx

    • 资源ID:64150712       资源大小:14.62KB        全文页数:7页
    • 资源格式: DOCX        下载积分:9.9金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要9.9金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    01 - 架构到底是指什么?.docx

    01 | 架构到底是指什么? 对于技术人员来说,架构是一个再常见不过的词了。我们会对新员工培训整个系统的架构,参与架构设计评审,学习业界开源系统(例如,MySQL、Hadoop)的架构,探讨大公司的架构实现(例如,微信架构、淘宝架构)……虽然架构这个词常见,但假如深究一下架构究竟指什么,大部分人或许并不肯定能够精确地回答。例如: 架构和框架是什么关系?有什么区分? Linux 有架构,MySQL 有架构,JVM 也有架构,运用 Java 开发、MySQL 存储、跑在 Linux 上的业务系统也有架构,应当关注哪个架构呢? 微信有架构,微信的登录系统也有架构,微信的支付系统也有架构,当我们谈微信架构时,究竟是在谈什么架构? 要想精确地回答这几个问题,关键在于梳理几个有关系而又相像的概念,包括:系统与子系统、模块与组件、框架与架构。 系统与子系统 我们先来看维基百科定义的系统。 系统泛指由一群有关联的个体组成,依据某种规则运作,能完成个别元件不能单独完成的工作的群体。它的意思是总体整体或联盟。 我来提炼一下里面的关键内容: 关联:系统是由一群有关联的个体组成的,没有关联的个体堆在一起不能成为一个系统。例如,把一个发动机和一台 PC 放在一起不能称之为一个系统,把发动机、底盘、轮胎、车架组合起来才能成为一台汽车。 规则:系统内的个体须要根据指定的规则运作,而不是单个个体各自为政。规则规定了系统内个体分工和协作的方式。例如,汽车发动机负责产生动力,然后通过变速器和传动轴,将动力输出到车轮上,从而驱动汽车前进。 实力:系统实力与个体实力有本质的差别,系统实力不是个体实力之和,而是产生了新的实力。例如,汽车能够载重前进,而发动机、变速器、传动轴、车轮本身都不具备这样的实力。 我们再来看子系统的定义。 子系统也是由一群有关联的个体所组成的系统,多半会是更大系统中的一部分。 其实子系统的定义和系统定义是一样的,只是视察的角度有差异,一个系统可能是另外一个更大系统的子系统。 根据这个定义,系统和子系统比较简单理解。我们以微信为例来做一个分析。 微信本身是一个系统,包含闲聊、登录、支付、挚友圈等子系统。 挚友圈这个系统又包括动态、评论、点赞等子系统。 评论这个系统可能又包括防刷子系统、审核子系统、发布子系统、存储子系统。 评论审核子系统不再包含业务意义上的子系统,而是包括各个模块或者组件,这些模块或者组件本身也是另外一个维度上的系统。例如,MySQL、Redis 等是存储系统,但不是业务子系统。 模块与组件 模块和组件两个概念在实际工作中很简单混淆,我们常常能够听到类似这样的说法: MySQL 模块主要负责存储数据,而 ElasticSearch 模块主要负责数据搜寻。 我们有平安加密组件、有审核组件。 App 的下载模块运用了第三方的组件。 造成这种现象的主要缘由是,模块与组件的定义并不好理解,也不能很好地进行区分。我们来看看这两者在维基百科上的定义。 软件模块(Module)是一套一样而相互有紧密关连的软件组织。它分别包含了程序和数据结构两部分。现代软件开发往往利用模块作为合成的单位。模块的接口表达了由该模块供应的功能和调用它时所需的元素。模块是可能分开被编写的单位。这使它们可再用和允许人员同时协作、编写及探讨不同的模块。 软件组件定义为自包含的、可编程的、可重用的、与语言无关的软件单元,软件组件可以很简单被用于组装应用程序中。 可能你看完这两个定义后一头雾水,还是不知道这两者有什么区分。造成这种现象的根本缘由是,模块和组件都是系统的组成部分,只是从不同的角度拆分系统而已。 从逻辑的角度来拆分系统后,得到的单元就是模块;从物理的角度来拆分系统后,得到的单元就是组件。划分模块的主要目的是职责分别;划分组件的主要目的是单元复用。其实,组件的英文 component 也可翻译成中文的零件一词,零件更简单理解一些,零件是一个物理的概念,并且具备独立且可替换的特点。 我以一个最简洁的网站系统来为例。假设我们要做一个学生信息管理系统,这个系统从逻辑的角度来拆分,可以分为登录注册模块个人信息模块个人成果模块;从物理的角度来拆分,可以拆分为 Nginx、Web 服务器、MySQL。 框架与架构 框架是和架构比较相像的概念,且两者有较强的关联关系,所以在实际工作中,这两个概念有时我们简单分不清晰。参考维基百科上框架与架构的定义,我来说明两者的区分。 软件框架(Software framework)通常指的是为了实现某个业界标准或完成特定基本任务的软件组件规范,也指为了实现某个软件组件规范时,供应规范所要求之基础功能的软件产品。 我来提炼一下其中关键部分: 框架是组件规范:例如,MVC 就是一种最常见的开发规范,类似的还有 MVP、MVVM、J2EE 等框架。 框架供应基础功能的产品:例如,Spring MVC 是 MVC 的开发框架,除了满意 MVC 的规范,Spring 供应了许多基础功能来帮助我们实现功能,包括注解(Controller 等)、Spring Security、Spring JPA 等许多基础功能。 软件架构指软件系统的基础结构,创建这些基础结构的准则,以及对这些结构的描述。 单纯从定义的角度来看,框架和架构的区分还是比较明显的,框架关注的是规范,架构关注的是结构。框架的英文是 Framework,架构的英文是 Architecture。Spring MVC 的英文文档标题就是Web MVC framework。 虽然如此,在实际工作中我们却常常遇到一些似是而非的说法。例如,我们的系统是 MVC 架构我们须要将 android app 重构为 MVP 架构我们的系统基于 SSH 框架开发我们是 SSH 的架构XX 系统是基于 Spring MVC 框架开发,标准的 MVC 架构…… 原委什么说法是对的,什么说法是错的呢? 其实这些说法都是对的,造成这种现象的根本缘由隐藏于架构的定义中,关键就是基础结构这个概念并没有明确说是从什么角度来分解的。采纳不同的角度或者维度,可以将系统划分为不同的结构,其实我在模块与组件中的学生管理系统示例已经包含了这点。 从业务逻辑的角度分解,学生管理系统的架构是: 从物理部署的角度分解,学生管理系统的架构是: 从开发规范的角度分解,学生管理系统可以采纳标准的 MVC 框架来开发,因此架构又变成了 MVC 架构: 这些架构,都是学生管理系统正确的架构,只是从不同的角度来分解而已,这也是 IBM 的 RUP 将软件架构视图分为闻名的4+1 视图的缘由。 重新定义架构 参考维基百科的定义,我将架构重新定义为:软件架构指软件系统的顶层结构。 这个定义看似很简洁,但包含的信息很丰富,基本上把系统、子系统、模块、组件、架构等概念都串起来了,我来具体说明一下。 首先,系统是一群关联个体组成,这些个体可以是子系统模块组件等;架构须要明确系统包含哪些个体。 其次,系统中的个体须要依据某种规则运作,架构须要明确个体运作和协作的规则。 第三,维基百科定义的架构用到了基础结构这个说法,我改为顶层结构,可以更好地区分系统和子系统,避开将系统架构和子系统架构混淆在一起导致架构层次混乱。 小结 今日我为你梳理了与架构有关的几个简单混淆的概念,包括系统与子系统、模块与组件、框架与架构,说明了架构的定义,希望对你有所帮助。 这就是今日的全部内容,留一道思索题给你吧。你原来理解的架构是如何定义的?对比我今日讲的架构定义,你觉得差异在哪里? 欢迎你把答案写到留言区,和我一起探讨。信任经过深度思索的回答,也会让你对学问的理解更加深刻。(编辑乱入:精彩的留言有机会获得丰厚福利哦!)

    注意事项

    本文(01 - 架构到底是指什么?.docx)为本站会员(ylj18****41534)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开