01 | 架构到底是指什么?

01 | 架构到底是指什么?

朗读人:黄洲君    09′19′′ | 4.27M

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

  • 架构和框架是什么关系?有什么区别?

  • Linux 有架构,MySQL 有架构,JVM 也有架构,使用 Java 开发、MySQL 存储、跑在 Linux 上的业务系统也有架构,应该关注哪个架构呢?

  • 微信有架构,微信的登录系统也有架构,微信的支付系统也有架构,当我们谈微信架构时,到底是在谈什么架构?

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

系统与子系统

我们先来看维基百科定义的“系统”。

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

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

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

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

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

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

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

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

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

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

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

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

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

模块与组件

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

  • MySQL 模块主要负责存储数据,而 ElasticSearch 模块主要负责数据搜索。

  • 我们有安全加密组件、有审核组件。

  • App 的下载模块使用了第三方的组件。

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

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

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

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

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

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

框架与架构

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

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

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

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

  2. 框架提供基础功能的产品:例如,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 视图”的原因。

重新定义架构

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

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

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

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

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

小结

今天我为你梳理了与架构有关的几个容易混淆的概念,包括系统与子系统、模块与组件、框架与架构,解释了架构的定义,希望对你有所帮助。

这就是今天的全部内容,留一道思考题给你吧。你原来理解的架构是如何定义的?对比我今天讲的架构定义,你觉得差异在哪里?

欢迎你把答案写到留言区,和我一起讨论。相信经过深度思考的回答,也会让你对知识的理解更加深刻。(编辑乱入:精彩的留言有机会获得丰厚福利哦!)

版权归极客邦科技所有,未经许可不得转载

精选留言

  • 公号-Java大后端
    架构是顶层设计;框架是面向编程或配置的半成品;组件是从技术维度上的复用;模块是从业务维度上职责的划分;系统是相互协同可运行的实体。
    2018-04-28
    作者回复

    精炼!

    2018-04-28

  • 每天都在找小黄车
    搬砖的:“头,我们要造什么?”;(做什么系统?)
    工程师:“龙之梦商城”;(XXX系统,比如微博系统)
    搬砖的:“图纸画出来了嘛?”;(架构是怎么设计的?)
    工程师:“一楼主要以女性消费为主体、二楼以大众娱乐为主体、三楼以美食为主体”;(相当于微博系统中的各个子系统,比如评论子系统、动态子系统、消息子系统)
    搬砖的:“头,说人话”;
    工程师:“一楼有卖衣服、化妆品的,二楼有唱歌、看电影的,三楼有吃的”;(【模块】按照逻辑区分,比如存储数据模块、搜索模块、消息推送模块)
    搬砖的:“有没有很知名的店啊?”;
    工程师:“有的,一楼有香奈儿、优衣库...、二楼有好乐迪、万达影院....、三楼有海底捞、避风塘.....”;(【组件】按照物理区分,存储数据模块对应Mysql、搜索模块对应ElasticSearch、 消息推送模块对应Kafka)
    搬砖的:“对了,头,商城大门有啥需要叮嘱的施工规范不?或有啥简化施工工艺的新技术嘛?”;(有框架的可以用吗?)
    工程师猛吸了一口烟,把烟头扔在地上,用皮鞋左右撵了两下,缓缓从嘴里崩出四个字。 “老样子吧”。(Spring全家桶甩起来)
    2018-04-28
    作者回复

    极客时间卧虎藏龙,里面的用户个个都很有才,口才又好,长得又帅,我超喜欢😂

    2018-04-28

  • Ivan
    框架是规矩,架构是按照规矩做规划。系统是学校,子系统是班级,模块是学生老师,组件是课桌椅。每一层级的作用意义和范围不一样,要求和可复用度也不一样
    2018-04-28
  • 杜晓东
    我们要做的东西都能抽象为一个系统,架构既可做动词也可做名词,作为动词就代表系统的设计,作为名词就代表系统的表现形式。
    所以架构首先继承了系统的属性:
    0、系统整体有价值
    1、由多个有关系的个体组成
    2、涌现,整体大于个体之和,也就是文中说的“流”出来的新的价值
    系统的架构从无到有由人来执行,所以也具备人思考和交流的属性:
    0、思维带宽较小,不能同时考虑很多事情,需要把系统做分解(模块和组件)
    1、线性思想和交流,多维关系要降级到二维关系(4+1视图等多种方法论)
    2、人作为个体的个性化-也即多样性,架构没用统一标准,适合自己/团队/公司最重要。
    2018-04-28
    作者回复

    你已经开始解剖架构的本质了,后面章节会讨论这个话题。
    通常“架构”还是用作名词,动词就用“架构设计”,有的观点用“构架”,有点拗口和容易混淆,所以我一般宁愿用“架构设计”

    2018-04-28

  • blue
    系统与子系统:系统是由一系列有关联,按特定规则组成的个体,并且产生新的能力,而系统与子系统则是观察的交角度不同

    模块与组件:模块是从逻辑角度去看待,而组件是从物理角度去看待

    框架与架构:框架是规范也是约束,可以理解为封闭性的话题,定义好,让别人如何去使用,而架构是一种结构,是一种开放性的话题,如何去设计组织架构,如何让架构更具有拓展性,减少沟通错误成本
    2018-04-29
    作者回复

    提炼了精华,赞

    2018-04-29

  • 余红松-北京
    # 阅读笔记
    - 关于系统:
    系统和子系统其实都是系统,只不过在本业务里边的分层不同,只有顶层为系统,其他都为子系统,就像目录树一样,看你目录最深有多少层,
    - 模块向虚(逻辑),组件向实(代码)。
    - 框架向虚(规范),架构向实(结构)。
    2018-05-06
  • tick
    微信是系统,微信的登录是子系统,
    学生管理是系统,学生管理的登录就是模块,这是为什么呢,模块和子系统啥区别?
    2018-04-28
    作者回复

    子系统是独立运行的,模块是子系统的逻辑组成部分,如果学生管理系统规模很大(例如在线学校),需要支撑每秒上万的登录请求,那么学生管理的登录模块一样可以升级为子系统。

    2018-04-28

  • 小龙
    框架和架构其实不一定有什么关联关系。架构是为了实现某个功能而设计的一种结构方式。虽然架构一词高大上,但你只要实现了自己的功能,你的结构就是架构。有了架构,你就有了工作的思路和方向。框架是实现功能的一种规范,你必须在这种规范下工作。注意,定义中说框架是定义组建的规范,所以框架里面不一定非得有组建和模块。
    模块是从职责划分的角度来观察,实现某个功能的职责,称之为模块。比如登陆模块。要实现的某个功能,我们一般称之为模块。
    组件的本质是可以独立实现某项功能的零件。它的特点是独立,可替换
    组件与模块的区别是,组件可能是为了实现模块而实现的。但是实现功能的模块不能称为组件。
    2018-07-08
    作者回复

    点赞

    2018-07-09

  • 今夕是何年
    架构是顶层设计,框架是具体实现。
    2018-05-01
  • feiyue
    大道至简。架构是宏观整体,框架是微观组成。
    2018-04-28
  • CHaNniNG
    关于华仔的思考题,本人刚刚接触架构,之前作为开发人员理解的架构不是很深入,基本是按照各个技术组件的组合方式来理解的,架构做得好不好,主要看技术组件能否组合得好,并满足业务特性;今天听了华仔的讲解,发现我之前忽略的业务模块的组成这一方面而单单考虑技术点了,架构其实是可以从多个角度来进行阐述的。华仔的讲解让我对架构的概念有了更加清晰和全面的了解,谢谢华仔
    2018-04-28
  • felix
    之前理解的架构就包含2部分,逻辑架构和物理架构,现在知道了还有开发架构
    2018-04-28
  • patrick_momo🏠
    我理解的架构,是通过不同分工合作和识别不同生命周期为了一个组织或特定的目的而形成的树状结构,这种结构有利于在有限的时间内使组织内的角色完成相关的工作,从而达到业务增长的目的。而作者的这个架构应该更多地理解为软件架构,但是局限在顶层是否合适,还要看后续的文章内容阐述。
    2018-04-28
  • Ken
    系统架构主要描述一个系统有哪些子系统构成,每个子系统的职责,以及子系统之间如何交互。
    从技术角度来说,系统架构也会描述系统的技术栈,技术选型,以及高层次的业务流程。
    2018-04-28
    作者回复

    这种方式适合描述较复杂的后台架构,有的系统不一定有子系统的概念,但它们一样有架构,例如我们可以说mysql的架构,jvm的架构,linux的架构

    2018-04-28

  • Suclogger
    我觉得架构的定义也可以从逻辑和物理上拆分,从逻辑视角出发,可以认为是业务的各个模块的定义,从物理视角出发,可以认为是各个模块的实现之间是一一种什么方式交互合作。感谢作者的精彩分享,就是演讲者对专有单词的读音还要改善,比如nginx。
    2018-04-28
  • 弄花香满衣
    我理解的架构包括网络、机房、存储、容器、系统实现;其中系统实现约等于框架,比如经常用的MVC框架、redis、RPC等等
    2018-04-28
  • 海格
    老师您好,我是一名运维,我讲讲对运维架构理解吧,运维架构指,业务系统所用到的中间价,在运维视角合理的规划,实现可靠性,高性能的为业务系统提供支撑功能。还有一个就是把运维的日常工作柔和起来做一个运维平台,这个平台实现简单,高效的完成运维的日常工作听完老师今天的分享,我的理解就是把一个系统更加细化具体的分析出来,然后逐个实现,再整合,完成我们想让系统完成的功能。
    2018-04-28
  • joedong
    个人觉得架构是复杂事物构建过程中产生的需求,而且不仅是效率上的,还是必要性上,都需要架构的支撑。以此引申出的架构设计,架构搭建,架构维护升级等架构相关工作。
    类比建筑行业里面的架构,如果没有好的架构支撑,就无法搭建稳固的建筑"产品"。而且架构将不可变的要素跟可变的要素进行了分离,使到建筑的例如外观,装饰,内部空间等的变化(短时内)成为可能。
    所以回到软件产品(系统),架构的引入,确实也起到了类似的作用。而且越通用的架构越低层,但是同时也未必产品构建效率和产品整体性能较佳,所以需要根据不同类型的产品进行架构设计。比如网页显示型产品(web)跟功能调用型(输出类似json等数据)的,就会有不同的架构设计。
    2018-04-29
    作者回复

    软件架构和建筑架构貌似类似,实质上有本质区别,后面会阐述

    2018-04-30

  • Tunan
    我理解的架构就是功能划分,最后让整个软件成为架子,模块是乐高积木。在遵循已定接口规范下能按照产品需求自由组合模块之间的IO以达到需求效果。
    2018-04-28
    作者回复

    这种理解适合业务系统架构设计,对于一些高性能高可用的架构不是很合适,单纯的功能划分并不能够保证高性能高可用,只能保证功能完成。

    2018-04-28

  • 常江舟
    我原来理解的架构
    1.如果是单体应用这种,拿MVC来说,不管是前端还是后台,我说是MVC风格,各种前后端框架比如spring mvc,angular是各种风格的实现。这个时候别人问我软件的架构是什么,我说就是单体应用架构,顶多再描述一下,系统是动静分离,还有用到了哪些组件,原来我对组件的定义就是ngix,mysql,tomcat这些。这一点和今天老师讲的差不多
    2.如果是分布式系统这种复杂的软件系统,别人问及架构。我会比较多地描述系统该系统整理分为哪几块,对应老师今天说的子系统的定义,而没有像老师一样,从业务逻辑和物理视图,开发角度等不同的面去描述。如果问及具体的某一块,我会比较多地描述其上下游依赖关系,在高性能,高可用方面怎么做的。总结一下,感觉自己的定义比较含糊,除非写文档的时候才会做几张业务架构图,和中间件相关的技术架构图。老师给的定义很清楚,而工程上也确实需要这样的定义,真是学到了。特别是联想到RUP那句话,让我恍然大悟!
    2018-04-28
  • 撒哈拉的海马
    我理解的架构,针对特定的需求,选择某种技术或某些技术簇,并设计出一套解决此问题的串联方法和规则,用来定义各系统和子系统的能力以及它们之间的交互串联规则说明和方法。
    2018-04-28
  • 架构是基于业务的顶层设计,而框架是普遍应用。。特殊和普遍的关系。
    2018-07-02
  • 线条
    系统根据业务或功能划分为各个模块,某些模块可能又被升级为子系统; 模块中可能使用了很多组件来实现某些具体功能 ; 同时,也可能使用了某些框架来作为开发的基础,而架构则描述了各个子系统或模块间如何协调工作。不知这么理解合理不?
    2018-06-24
    作者回复

    理解正确

    2018-06-25

  • 千年孤独
    顶层结构=金字塔结构。纵横有序,方可牢固。
    2018-05-28
  • 阿飞
    模块是单一系统中的一个单元,组件可以存在各个系统中的,多个模块组成一个系统,独立运行的模块就是各个子系统,多个子系统组成一个系统
    2018-05-12
  • 田震宁
    An architecture is the the abstract design concept of an application. Basically, a structure of the moving parts and how they're connected.
    A framework is a pre-built general or special purpose architecture that's designed to be extended.
    If an architecture is the design of a structure, a framework is the architecture of a foundation. Frameworks are specifically designed to be built on or extended.
    2018-05-10
  • 雪甫
    我认为的架构必然结合公司或组织内部的沟通和组织形式、业务的行业规范和发展方向、研发和运维理念以及技术能力,所以软件架构我认为首先是3个层次的:业务架构、应用架构、技术架构。业务架构 是公司或组织内部 当前的沟通模式,换句话说用户的流程是什么?他们怎么用?也就是业务需求。应用架构是把用户的需求按照行业标准、产品规划和当前的研发能力进行结合得出最合适的功能设计,产品需求是这中间的一个产出;技术架构就是技术通常程序员说的架构,各个系统怎么有机的结合的一起,怎么快速的运维和故障处理。
    2018-05-04
  • 卫什么
    国家算一个系统,下面有很多的子系统,这些子系统内部又有很多其他系统。子系统相互关联又共通作用,维护国家运行。

    模块算逻辑划分,国家的组成经济,政治,文化,国防,教育……。
    组件算物理划分,三省六部等等。

    框架算规范,三权分立,或者皇权天授,或者君主立宪,或者基本人权

    构架算顶层设计 三省六部,三级议会,上下议院,等等
    2018-05-02
  • Cc.王小鱼
    //架构是对某一类系统的抽象定义,就好比一辆汽车的设计图;
    //框架是一组可重用,易扩展,经过良好的测试的软件组件。就如同组装汽车的流水线,我们不用理会汽车轮胎的生产过程,发动机的生产过程,xxx生产过程,只需要把各个生产出来的组件交给组装汽车的流水线(框架),那么就可以把汽车生产出来,说白了框架就是一个经过良好测试的生产机器;
    2018-04-28
  • 🔰夏天的味道
    我理解系统是业务所关心的,需要做出什么东西。架构是工程师所关心的,如何将这个系统落地。
    2018-04-28
  • 云辉
    架构就是对系统进行各个纬度的抽象定义,也就是老师说的顶层结构吧
    2018-04-28
    作者回复

    我能看懂你说的,但这句话太抽象,一般我不会跟别人这样介绍和解释,因为“纬度”指什么,“抽象”指什么,“定义”指什么,很难一目了然的看懂😂

    2018-04-28

  • 可见度户
    之前理解的架构:
    主要从业务和技术两方面,业务是对业务模块进行划分,由多个业务模块有机组合成一个大的软件系统;技术方面主要是考虑系统的分层及组件依赖关系,是从技术的角度去把握如何能过支撑业务模块,最后是从系统部署和运行角度考虑物理结构;
    现在理解的架构:
    理解了系统,子系统,模块,组件,框架等架构中必然涉及到的一些概念和之间的区别,其实框架就是对上述这些东西的合理的组合,来满足业务需求,从而形成下来的一个逐渐演变的逻辑结构,文中提到的4+1视图能过很好的从不同角度观察系统架构,架构不再是一个概念,而是在不同视角有不同的展现形式,我们只有把每个视角都做到合理切满足业务需求,组合起来应该就是一个合理的整体架构。
    个人愚见,望网友和老师指导,感谢老师分享
    2018-04-28
  • HZX
    框架是构建目标系统的基础设施。为目标系统的构建提供约束与支撑。约束规避风险,支撑节约成本。

    架构是部分组成整体的协作机制。
    2018-04-28
  • 夏大伟
    我原来认为系统架构是指软件系统的结构,结构应该包含两部分内容,一是组成部分,第二是各个部分之间的关系。我觉得我所理解的组成部分就是这节课程中所说的系统,子系统,模块,组件,而至于各个部分之间的关系究竟有哪些我还不是很清楚。
    2018-04-28
  • 罗烽
    之前理解的架构:
    很模糊,总觉得是所有功能模块化,都是从业务角度上去说的,然后在想实现这些模块,需要什么语言,什么数据库,没有仔细理解过什么是架构(还比较年轻,没经历过这些设计吧😂)
    今天的理解:
    架构,系统顶层结构。模块化,是从业务角度来划分系统,而组件,则是可复用的单元(应该是类似中间件)。而我们要处理的就是一个新的业务,从模块上划分,它的结构是什么样的,哪个模块可以复用什么组件。
    2018-04-28
  • Even
    以前对架构的概念比较模糊,只知道物理架构图和逻辑架构图,关于架构这个词很好人都没有讲清楚,今天听了运华的分析,对架构这个概念有了更清晰的理解。
    2018-04-28
  • cruise
    一直对这些概念都不是很清晰,跟客户沟通时,有时候也把客户弄的晕头转向,呵呵,倒是让他们感觉很高深的样子。李老师讲完后,的确清晰了不少,但仍需要多看几遍。另外在工作中也要有意识的正确运用这些概念和词语。
    谢谢李老师,👍
    2018-04-28
  • 叮咚叮咚
    个人简单理解 不知道对不
    逻辑架构:关注业务模块以及模块间的关键和其他系统间的交互
    物理架构:系统的物理网络部署拓扑 关注系统的物理组件 例如 负载均衡 存储 消息通讯
    开发架构: 关注系统开发使用框架
    2018-04-28
  • Yulean
    我理解的架构有两个层次,:
    1)是文章中提到的物理部署架构,从用户端—ngix—web 站点—ngix—wcf—db整个流程模块所涉及到的架构设计;
    2)是系统内部模块与其他系统交互的架构,有点类似文章中的业务架构和系统使用框架两块结合在一起产生的东西。
    问题是,在脑海中描绘当前所负责系统的架构时,经常不知道以什么为边界,或者说以什么做最小颗粒度?
    2018-04-28
  • 何磊
    我以前的理解更多是站在物理角度划分,比如一个电商系统:
    1.webserver怎么配置,如何去做负载,如何防刷;
    2.持久划采用什么技术,怎么做主从,如何数据保证一致性;
    3.缓存结构如何设计,如何部署;
    4.通过代码利用以前的物理资源完成业务逻辑,把他们整个起来。
    以上就是我以前理解的架构,
    通过阅读本文,我觉得架构其实可以用多个角度来看待,它的包含可以根据角度不同而不同。
    而还有个比较懵的疑问:感觉架构既可以包含系统,而每个系统又有自己的架构。二者也许不仅仅是包含与不包含那么简单。再去读一遍理解下。
    2018-04-28
  • 刚子
    之前理解的架构定义是可以很恰当的满足当前业务需求的要求,让人看起来很自然

    另外老师文章中提到的架构关注的结构,而框架关注的是规范,仔细想来,的确如此,架构设计完成之后好比大厦的构造图,而框架好比使用架构某一部分需要遵守的规范

    个人想法,多多交流😀😀
    2018-04-28
  • 邓呵呵
    我理解的架构就是对一个新系统或者功能需求给出一个新的或者基于当前环境最优方案,方案包括使用哪些中间件和框架,以及环境中可能出现的极端复杂情况及解决方案,我的视角可能比较偏开发一些
    2018-04-28
  • winston
    之前理解的架构,是为了支撑业务发展,采取的技术集合。
    2018-04-28
  • 小Z
    架构是顶层架构 说的再通俗点 就是说这个东西是怎样组成的吗?
    2018-10-15
    作者回复

    是的,但要注意“顶层”两个字,不要陷入细节

    2018-10-16

  • 苏上
    系统与子系统、模块与组件、框架与架构,理解这几个概念真的太重要了。
    在软件生命周期中,需要从不同角度去解读系统,输出软件架构视图。4+1视图得好好掌握。

    2018-10-11
  • lucoffee
    这是我第一次学习架构这个词。
    2018-10-10
  • 网络架构,是模块和组件的总系统
    2018-10-10
  • Dylan
    刚看完第一节课,重新整理了一下之前对这几个概念的理解,感觉来晚了~
    还有这里的评论也很精彩~
    2018-10-10
    作者回复

    一点不晚😄

    2018-10-10

  • Leo
    老师,我还想深入理解一下,您说的架构解决的是系统复杂度问题,那除了技术复杂度外,业务复杂度也是应该关注的,而业务复杂度就是我说的产品边界,换个理论的词来说就是领域模型,所以,从产品或者业务的角度看架构的话,能否说架构就是产品边界呢?当然,为了清晰化,在定义产品边界的时候,产品经理需要通过清晰的模型来表达业务范围
    2018-10-10
    作者回复

    业务复杂度也是复杂度的一种呢,我是放在可扩展里面讲的,不同的系统有不同的复杂度,例如nginx的复杂度就是高性能,淘宝的复杂度是高性能高可用加业务复杂度,架构本身不是产品边界,产品边界决定架构

    2018-10-10

  • Leo
    从产品经理的角度看:架构能否理解成产品的边界?
    2018-10-08
    作者回复

    不要这样理解,产品边界理解起来很泛,不同的人之间交流困难

    2018-10-10

  • 李皮皮皮皮皮
    软件架构是软件系统的顶层结构👍
    2018-10-07
  • 大大大懒猫
    架构类似建筑的设计图,框架类似设计理念,系统和模块是功能上的划分和细化,组件是可复用的实现具体功能的业务逻辑,组件可以构成模块和系统,系统和模块也可以是其他架构中的组件
    2018-10-05
  • 清源
    感觉架构就是面向业务的,就是去做一件事,怎样做才能做得漂亮
    2018-09-29
    作者回复

    架构当然要面向业务,要不要漂亮真不一定,看后面的架构原则😊

    2018-09-29

  • 清源
    我之前以为架构就是技术选型,例如数据库用什么,连接用什么,UI展示用什么等
    2018-09-29
    作者回复

    技术选型是架构设计一部分

    2018-09-29

  • 雪熊
    我原来理解的架构就是组件之间的关系,架构师的职责就是设计组件的各种关系并保证高可靠高可用高安全高性能,肤浅了。
    2018-09-20
    作者回复

    不是每个架构都要求四高的,事实同时满足四高的架构成本会非常高

    2018-09-21

  • 神龙大侠886
    老铁666,都把我绕晕了
    2018-09-18
    作者回复

    这已经是我梳理后的,写作的时候为了明确这一堆东东,搞了一两周

    2018-09-19

  • Geek_2b5152
    感谢作者分享
    2018-09-04
  • deer
    收获颇多,建议老师最好结合那个学生管理系统的例子多画些图来讲,一般的系统的架构是什么样子,学生量很大(网校)应该怎么去区分...
    2018-09-02
    作者回复

    架构的图网上很多,关键是要理解为什么架构是这样,有什么优点和缺点

    2018-09-03

  • 陈华应
    原来的理解是一个系统的架构,分层,再按照模块来划分,再混合存储,中间件,负载,高科用这些揉和在一起,没有清晰的认识。
    2018-08-29
    作者回复

    一看就是做业务后台的😄

    2018-08-30

  • petit_kayak
    在我看来,某一层级的架构就是它的直接子模块的组合模式,包括形式、交互方式和公共服务的定义
    2018-08-21
  • Tomma
    我理解的架构,就是从逻辑视图(横向广度)出发,可以将系统划分为为哪些模块,各个模块有什么内在是联系,以及如何划分服务,再从物理视图(纵向深度)出发,看系统可以分为哪些层,每一层可以采用哪些组件来完成。最后看一下系统可能的瓶颈在哪里,以及如何解决。
    2018-08-19
  • 李杰
    架构是系统的顶层设计,即要高屋建瓴,又要兼顾实际。

    在工作中,常常把对架构的片面理解(自身的关注点),当成了架构的全部,还为此与他人争论,有点盲人摸象的感觉。

    文中提到了逻辑架构、开发架构、物理架构,在实际工作中,可以理解为4+1视图。要看清楚一个系统的架构,需要不同的视角,需要聚焦,这方面可以参考六顶思考帽。
    2018-08-16
  • 诗坤
    架构是系统的整体设计,它将系统的多个关联个体组合在一起,以一定的规则运行,并对内或对外提供各种服务。比如把mysql,redis,ngnix等个体在一起,架构的目的是选择更合适当前业务场景的,运行效率更好的软件或者硬件,将他们以最好的方式组合在一起以提供服务。框架是为了实现某个业务场景或者某个标准规范而抽象的基础软件服务,比如某个公司为了适应自己的业务发展自己开发的底层框架,比如实现了mvc的laravel框架。框架的作用是提供一些基础的软件服务,主要是为了让业务代码能更好组合在一起,相当于一种规范。组件为了复用提炼出来的软件单元,它的主要点是复用。
    #以前理解的架构师应该是框架师。😄
    2018-08-16
    作者回复

    架构师的范畴更广一些

    2018-08-16

  • kimi
    我的理解架构就是模块、组件的组装,即顶层设计,框架就是规范或有基础功能的规范
    2018-08-14
  • beiler
    除了阅读作者的笔记,看评论可以说是答疑了
    2018-08-13
  • 木木
    架构是一个整体,就好比一栋房子的地基,规划好房子的格局,能承受多少层等。
    其次,我理解的框架是一种工具或者组件,以此来快速帮助我们来实现这个架构
    架构其实也是不断地在变化和演进的。会随着业务阶段、层级的需求而不断地演化。
    2018-08-12
    作者回复

    严格意义来说,架构不是地基,地基也是架构的一部分而已,架构是整栋房子的结构,包括地基,楼层,布局等

    2018-08-13

  • 文竹
    我原理理解的架构是这样的:基本上等同于物理视角的架构,比如一个学生管理系统包含前端,后端服务,redis,mysql。

    从本文中学到了,可以从多个角度来看系统就会得出不同的架构即顶层系统结构,比如4+1架构图。


    那么有一个问题,一般在架构设计过程中,我们需要使用哪些视角的架构呢?
    2018-08-12
    作者回复

    逻辑视图和物理视图用的比较多

    2018-08-13

  • oscarwin
    架构是一个系统的顶层设计,从不同的角度划分这个系统的架构,会有不同的结果。框架是为了遵循一套固定的协议或者方法而生成的半成品系统。组件是从技术上可以复用的零件,比如消息队列。模块是从业务角度去拆分一个系统。
    2018-08-12
  • godtrue
    小结

    1:架构-这个词语不好理解,换成架构设计好理解一些,是软件开发之初对于使用什么技术,系统设计成什么样子,各个功能模块或子系统如何协助的一种规划

    2:框架-是面向编程或配置的半成品,业务无关且必须的代码开发已经被其他牛逼的人或团队给做了,我们只需要按照框架的规则填充业务相关的代码就可以了

    3:组件-是从技术维度上的复用,某些常用的功能无需二次开发,可直接复用已有的

    4:模块-是从业务维度上职责的划分,不同的模块处理不同业务,分开来开发和使用,用于降低复杂度

    5:系统-是相互协同可运行的实体,可大可小,复杂或简单都可以,也即是我们最终想要的东西,是软件组成的最核心的部分

    架构设计,我觉得除了设计的方法论,技术的积累也是必须的,而且是前提,否则怎么对比孰优孰劣,该选择什么放弃什么,怎么清楚哪些技术能支持多久,还有成本、工期、实现的复杂度等问题也需要考虑一并考虑。
    2018-08-12
    作者回复

    最后一段话很关键,架构师要求技术广度和深度并重

    2018-08-13

  • Home
    架构就是系统的总体布局,明确需要承担具体职责的部件。
    2018-08-11
  • snail
    架构是什么?

    首先理解系统和子系统、模块和组件、框架和架构。

    系统与子系统:
    系统泛指由一群有关联的个体【点】组成,根据某种规则运作【线联系】,能完成个别元件不能单独完成的工作的群体。
    子系统也是由一群有关联的个体所组成的系统,多半会是更大系统的一部分【个人觉得系统和子系统的关系是在一个高的层面还是在一个下面细的层面】。

    模块与组件:
    软件从逻辑的角度来拆分系统后,得到的单元是“模块“ - Module。
    软件从物理的角度来拆分系统后,得到的单元是”组件“ - Component。

    框架和架构:
    框架 - Framework
    架构 - Architecture

    重新定义架构:软件架构指软件系统的顶层结构。


    思考题:原来理解的架构是如何定义的?
    为了完成一个具体的业务而在逻辑上拆分出系统、子系统和模块;在实现上选择适合的框架和组件并连通;在部署上规划出多机之间的关系。对架构的定义从角度和层面两个维度。
    2018-08-09
  • Arthur.Li
    看了这节课对架构的概念更深刻了。以前只是模模糊糊的知道架构是对一个系统做整体规划的,现在学到了架构应该从业务逻辑上,物理上等去考虑,以前也想过,到没有这么细致
    2018-08-06
    作者回复

    有用就好😄

    2018-08-07

  • 湛蓝露白
    4+1视图这个很关键,建议作者以实际系统为例讲一讲怎么分析,怎么画
    2018-07-30
    作者回复

    实际应用不多,所以没有特别讲

    2018-07-31

  • wuhulala
    架构 是整个系统的生命周期 而系统的实现则是由一些框架搭积木而成
    2018-07-29
  • liyue326
    之前的理解就是技术选型 可扩展性。too young to simple
    2018-07-21
    作者回复

    可扩展性是其中一种

    2018-07-22

  • 乘风
    首先按需分类,有哪些模块、哪些组件,哪些模块还可以抽出来作为组件使用,然后组装:模块和模块、模块和组件按一定的规则组装,组装之后就是系统,我理解的架构是,分类、职责、运行条件,
    2018-07-16
  • 架构,框架,系统,子系统,模块,组件。顶层结构,关联,规则
    2018-07-15
  • Linky
    架构是是对系统的最抽象的最上层的设计,
    框架是已经存在的解决某类问题的规范
    2018-07-14
  • tangfengr
    我理解的架构主要是从业务模块划分,技术实现两个方面。业务模块也像搭积木,每个积木块要承载一定的功能,尽量做到边界清晰,沟通简单。技术实现方面要考虑性能要求,网络规划,安全要求,针对这些要求选择适合的技术栈或者框架,综合考虑其他环境条件选择一个技术方案。这个过程需要了解特定框架的优劣点,积累素材,确保用起来不会有后遗症。
    2018-07-03
    作者回复

    你说的比较适合比较大的业务系统,一些小的系统可能都不需要模块划分,一些中间件系统也不一定划分为具体模块

    2018-07-04

  • IvanEye
    您好,想请教个问题。架构模式和架构风格有什么区别?
    我找了些资料,说法各异,有说只是说法不同,有说模式解决了特定问题。但没有确切的区分。
    我理解的是:架构模式类似设计模式,是解决特定问题的套路。架构风格只是限定了一些约束,并不解决特定问题。
    就像书法,横平竖直是模式,宋体黑体是风格。
    2018-07-03
  • Steven⁰⁰⁸
    现在做一个系统,系统下有多个模块:单点登录、监控、运营、升级等,现在利用maven multiple module模式开发,基础实体或者说通用实体被抽离到base module,各系统间调用通过spring cloud提供服务接口调用,但现问题是各系统间还有很多重复的代码 ,请老师指导下
    2018-06-26
  • ye_ibl
    架构:一个系统由什么子系统组成,各个子系统负责什么功能,各子系统之间怎么沟通,就是这个系统的结构
    框架:一种软件开发的规范,带有系统开发的基础功能。
    2018-06-24
  • ye_ibl
    架构:一个系统由什么子系统组成,各个子系统负责什么功能,各子系统之间怎么沟通,就是这个系统的结构
    框架:一种软件开发的规范,带有系统开发的基础功能。
    2018-06-24
  • IvanEye
    个人觉得架构包含两个层面:架构过程和架构结果。
    过程是特定约束下的一个个的决策,结果是最终交付。
    所以我总结的架构是:特定约束下的决策结果。
    2018-06-19
    作者回复

    你这个定义比较难理解,实际上有点像是定义了“架构设计”

    2018-06-19

  • 明翼
    老师请教个问题,画架构图我们一般是以模块为单位话还是以组件那?
    2018-06-17
    作者回复

    架构图有不同维度,从物理的视角观察架构,就画组件,从逻辑的视角观察架构,就画模块,更多可以看参考架构4+1视图

    2018-06-19

  • poetess
    架构图那块,Nginx下边不应该是应用服务器嘛,新手有点懵
    2018-06-11
    作者回复

    web服务器就是你说的应用服务器

    2018-06-11

  • 玛莎拉蒂不拉妹
    之前的理解是软件架构就像是人的骨骼一样,把各种软件组成部分系统的组织在一起 优化在一起 从而更好的达到业务的目的。
    2018-06-11
  • mαnajay
    我们所说的系统是对所做业务总量上的一个宏达的定义,系统是由业务模块构成,模块一般是同一业务范围的概念,所以特别复杂的子模块也可以称为一个子系统。而模块由多种组件构成,组件一般为技术角度可重用的功能单元。
    2018-06-05
  • 探索无止境
    提个建议,后续的朗读能不能跟开篇一样的音量,音量太小听起来不方便
    2018-06-04
  • Geek_5b3ccb
    模块和组件不太理解。模块是能实现某一功能的独立代码组,组件也是。但我认为模块和组件不能以逻辑和物理来区分。物理一般指的是磁盘,内存。比如分布式数据库,就是逻辑上是一个数据库,物理上存在不同地方的数据库集合。我可以这么理解模块和组件吗?组件强调被复用功能代码。模块强调是被调用的功能代码。比如连接池是一个组件,用户登录是个模块。
    2018-06-01
  • 汉克虎@晓火花xhhua.com
    架构就是类似人体结构,是多维立体系统,分为逻辑层神经系统从中心到边缘,物理层骨骼肌肉,应用层五官功能等,所有层组合起来的结构,也可以理解为建筑结构,软件本身也是来源于真实世界,也是实际生活中的系统架构映射!
    2018-05-31
  • JUNE
    我理解的组件是独立的、可复用、可扩展的。

    而模块是按照功能逻辑拆分的不可单独运作的单元。

    还有那个MVC的图,为什么View被两个箭头指着,View不应该指向Controller吗?求解
    2018-05-30
  • may
    架构要明白系统有哪些个体构造,个体之间是如何运作得
    2018-05-30
  • wessonwang
    讨论架构,
    先是要明确在什么粒度(层面)讨论的,比如是要讨论一个公司的业务架构,还是要讨论一个订单系统。
    明确好粒度后,架构讨论的就是系统相关主体(某一粒度/层面)之间的交互与依赖关系了。
    2018-05-29
  • 千年孤独
    “框架是组件的规范”这句话我觉得有些不够恰当,应该是“框架是模块的规范”。MVC是框架,而框架是一种逻辑概念,从逻辑角度看MVC框架的子部分就应该被称为“模块”。
    2018-05-28
    作者回复

    这是从维基百科摘录的,某个组件按照mvc框架来构建

    2018-05-29

  • Geek_59a17f
    理解了模块和组建的区别,框架和架构的定义。
    老师的声音很好听。
    2018-05-28
    作者回复

    不是我读的,是专业的播音员读的😂😂

    2018-05-28

  • 景三
    用人来比喻,架构是骨头,搭起整个软件。框架是大脑,约束软件应该怎么做。模块是吃喝拉撒走,负责不同的功能。组件是躯干四肢头,组成一个人。而子系统就是呼吸系统运动系统,属于软件的一部分,独立工作却又遵从指挥
    2018-05-28
    作者回复

    很形象😂

    2018-05-28

  • 鲸息
    架构关注非功能性需求
    2018-05-26
    作者回复

    通常的说法叫做“质量需求”

    2018-05-27

  • 伟迪
    我认为,架构是在某个前提条件下,对整个计算机软件结构的离散 抽象设计。离散是分散能力,抽象的是合并能力。既然是抽象离散,每个人离散抽象的方式不同,如果这个架构没有前提要求,所以任何人对一个软件的架构设计都是对的。但是,现实中每个开发任务总会有前提条件,比如常见的这个软件需要有可扩展性,有可复用性等,架构设计因此才有了评判标准。
    2018-05-24
  • andy
    框架里面都有自己的架构思想吧?比如spring框架
    2018-05-23
  • 代码狂徒
    大神,针对您所提出的相关定义,是不是也可以用图的形式显示出来,比如本篇结尾的定义,这样可能更直观,因为有可能我们在各自的理解中产生跑偏,
    2018-05-23
    作者回复

    里面有3张图呢,虽然简单,但也是架构

    2018-05-23

  • Joker
    是不是可以这么认为,就是做架构就是对于解决一个或者一类问题,构建一个系统,你需要为这个系统根据业务划分模块,需要加入能组合起来的组件和框架,然后你需要构建一系列规则,让这些组件和框架跑起来,各自发挥各自的能力,来实现一个个模块,然后这些模块又组合起来成了整个系统,所以做架构需要很熟悉业务,会业务逻辑划分,要熟悉很多框架,组件,知道他们的能力,熟悉怎么组合他们完美的运作起来!
    2018-05-22
    作者回复

    非常正确:问题,模块,规则,系统,架构四要素😃

    2018-05-23

  • howie6879
    系统是基于 Spring MVC 框架开发 语音读的是架构开发 读错了还是写错了?
    2018-05-21
    作者回复

    应该是“框架”

    2018-05-21

  • 万历十五年
    系统的架构就是结构。从逻辑角度看,整个系统由各具特色的子系统组成,每个子系统都是提供特定功能的模块;从物理角度看,整个系统由不同的硬件组成,这些硬件也称为组件。这些逻辑模块或物理组件的组合规范,称为框架。
    2018-05-19
  • 轩辕十四
    框架约束怎么做,哪些事能做,哪些不能做;
    架构侧重拓扑和信息流转
    2018-05-19
  • Jet
    顶层结构……的顶层如何理解?
    2018-05-18
  • 李笑天
    运用框架开发模块组成系统,系统依赖组件,子系统相互协作组成更大的系统
    2018-05-18
  • 软件架构=业务模块/组件定义+调用关系【接口】+框架
    2018-05-17
  • missa
    自己理解的架构是从服务器到数据库再到业务代码。怎么部署分布它们。它们之间又去怎么通信等等
    2018-05-15
    作者回复

    这是部署架构

    2018-05-16

  • 彡工鸟
    回过头来再读一遍,就物理的部署架构来说,是不是不应该标明具体技术组件呢?例如说nginx-web容器-mysql中的nginx和mysql,应该nginx替换为web服务器或者反向代理或者负载均衡(就看对这一层的具体定位了)。同理mysql应该替换为存储,甚至更具体的主备,主备备
    2018-05-13
    作者回复

    标明更好理解呢

    2018-05-14

  • ^_^
    架构是连接业务和IT的桥梁
    2018-05-13
    作者回复

    最好别这样理解,太虚了,不懂的人还是不懂😃

    2018-05-14

  • 孙振超
    架构是决定系统有那些组件组成以及这些组件的关系。在实际的工作中又会有业务架构和技术架构的区分,也可以简化为分层模块图,层与层之间相互依赖,层内的模块组合起来为上一层提供服务。
    2018-05-12
  • 张彦军
    架构,软件或系统的顶层设计。它是为某一需求或某一业务的实现或落地,而采取的构件及构件间联系的设计,一般会画一个架构图,依据的标准 规范,层次结构,包括硬件支撑环境等。
    我考过了软考中系统架构师的考试,记得里面有逻辑视图 实现视图 部署视图 用例视图,但感觉缺乏学以致用。
    谈一下我对架构和框架的理解:框架是为减少相似业务的重复开发,在遵守某一规范下,形成的具有基础功能的软件系统。基于此框架开发,只要遵守其规范,应该是更快,更稳定。框架实现时,本身需要事先架构好,里面有架构的约束,架构的东西。
    2018-05-10
    作者回复

    4+1视图挺有用,但一般团队不会这么正规的操作,通常情况下会挑选最重要的一两个方面展开

    2018-05-11

  • zjhiphop
    我之前理解的架构设计是在一定约束条件下选择的符合某种规范的结构设计
    2018-05-10
  • fatme
    软件架构指软件系统的顶层结构。由于软件系统可以在不同层次上划分为子系统,所以每个软件子系统都有自己的架构。而框架的基础是某种规范,规范也包括了结构部分,所以框架隐含了某种架构,框架是这种架构的逻辑实现(规范)和物理实现(基础功能)。另一方面,由于现代的软件系统越来越复杂,不存在包含系统所有方面的规范。所以,对于复杂的系统来说,某个规范只会应用到这个系统的一部分。这样,对应的框架只会影响到某个子系统。对于这样的复杂系统来说,内部会包含多个框架,甚至多种规范。它的顶层结构,也就是架构,是跨越规范和框架的。而对于简单的系统,它的架构往往等同于它使用的框架所隐含的架构。
    2018-05-10
  • 山泉
    从逻辑的角度来拆分系统后,得到的单元就是“模块”;从物理的角度来拆分系统后,得到的单元就是“组件”。老师还举了例子,提壶灌顶的感觉,赞!
    2018-05-10
    作者回复

    希望你“醍醐灌顶”,别“提壶”灌顶,皮一下很开心😂😂

    2018-05-10

  • 大表姐吴永秀
    之前容易将模块和组件混淆。现在很清楚了。模块是一种功能上的逻辑划分。组件是物理划分,组件是可重用的,可以集成到系统中的产品。
    2018-05-10
  • 高阳路人
    从逻辑的角度来拆分系统后,得到的单元就是“模块”;从物理的角度来拆分系统后,得到的单元就是“组件”。划分模块的主要目的是职责分离;划分组件的主要目的是单元复用。
    2018-05-09
  • 孔祥帅
    个人理解,要区分级别,然后才能谈框架和架构。代码级别谈框架,系统级别谈架构。其实架构和框架意思是一样的的,只是指定的级别不同
    2018-05-09
    作者回复

    框架和架构意思不同

    2018-05-09

  • 杨陆伟
    从物理角度拆分,分为nginx,mysql,web服务器这些组件,这里说的有点牵强,为了概念而概念了。其他都还挺好
    2018-05-08
    作者回复

    这是为了说明简单

    2018-05-09

  • aslong龙
    我一直觉得架构是很抽象的概念,当别人问我自己做的产品架构是什么样的时候,我往往会从分层的角度来解释,最底层是业务无关的模块,中间层是与业务有关联的功能模块,顶层就是各个产品应用模块,也不知道这样理解是否合适。订阅这个专栏就是希望跟着老师认真地学习架构知识,成为一名架构师。
    2018-05-08
  • Enjoystudy
    架构决定各子系统如何交互,如何协作,框架是很多前人总结的开发经验然后总结出的一套可复用的代码,便于更好的搭建子系统,组件是子系统内对各功能模块的划分,组件大了可以抽取出来单独部署,就变成了子系统
    2018-05-07
  • 苟哥
    拿web应用来说,我之前理解的架构是从硬件设备(例如服务器配置)到应用层等7层协议的综合解决方案的设计,不知道这样理解可行否
    2018-05-07
    作者回复

    正确,但这只是从分层协议角度来拆解架构,还有其他角度

    2018-05-08

  • 文竹
    听完了,对这六个概念,系统/子系统,架构/框架,模块/组件还是很模糊。感觉这六个概念在特定场景可以相互转换似的。
    2018-05-07
  • 张立春
    这是技术得到专栏吗!非常喜欢!
    2018-05-07
  • QuincySx
    我曾经理解的架构
    我之前以为架构就是组件功能的清晰划分,之前的想法很简单
    2018-05-07
  • Dear。
    个人浅见是
    架构是如何把需要做的业务系统/中间件 等按一定的方式做出来,用合适的技术去做合适的事儿,满足一定的场景;
    框架是一个模板,或者类似半成品,有助于我们更好的去实现系统/中间件等.但是框架其实不是必须品.比如mvc,如果我们不用spring mvc等开源框架,其实也可以用servlet.
    2018-05-06
  • JasonZ
    现在主要做的都是业务架构设计。都是从业务的角度出发,业务单元模块化。然后所谓的微服务架构设计。没有从功能模块去设计,这就是没有中后台的概念
    2018-05-06
  • 孙晓明
    架构是 对如何实现一个系统进行说明,可以分3个纬度:物理结构,逻辑结构,系统质量(QoS)。物理结构纬度从底向上分为硬件、操作系统、中间件、应用系统等部分;逻辑结构分为客户层、表示层、业务层、持久层、资源层等;系统质量指性能、可靠性、可用性、可扩展性、可升级性、安全等等一系列的非功能需求。三个纬度可以组成一个立方体结构,纬度之间都有相互关系。
    2018-05-05
  • fan
    架构是对事物宏观,整体得认识。逻辑架构:认识事物看不见得部分(模块),物理架构:认识事物有形可见得部分(组件)。而框架就是实现架构过程中需要遵守的规范和约定。
    2018-05-05
  • 波波安
    软件架构是指系统的顶层结构,应该从全局考虑。以前考虑的架构多数从技术角度出发,从课程中学到架构可以从不同角度分解,课程中说到的有物理部署角度,业务逻辑角度,技术规范角度等。
    2018-05-05
  • simiam
    听了华哥的文章对几个概念有了新的认知。我之前一想到架构,脑袋中浮现的是一个分层的框图。马上会想每一层应该提供什么功能。请问下什么时候才会考虑具体功能呢?
    2018-05-05
    作者回复

    架构和具体功能分不开,架构的复杂度分析来源于对功能的理解和剖析。

    做完架构设计后有方案设计,方案设计就是具体的功能设计。

    2018-05-05

  • 小河
    第一天:学习了系统与子系统、模块与组件、框架与架构、架构的概念等内容,系统是整个项目,子系统是相对于更大系统的说法,模块是业务逻辑角度的拆分目的是职责分离,组件是物理角度拆分目的是单元复用,框架是规范ssm,架构是结构,架构(顶层结构)可以分为很多层面:
    比如从业务逻辑角度模块登录、朋友圈等,
    从物理部署角度组件nginx-web服务器mysql等、
    从开发规范角度MVC。

    附加:
    系统是由一群有关联的个体组成。
    系统内的个体需要按照指定的规则运行,规定了个体分工和协作的方式。
    系统能力与个能能力之和有本质区别。
    框架是组件规范MVC,
    是提供基础功能的产品 spring security、spring jpa。
    2018-05-05
  • 明才
    我所理解的架构是,过程性和结构性。过程性是指架构设计是一个过程,输入是业务输出是架构。结构性指的是架构包括了开发架构,数据存储架构,网络架构,部署架构,安全架构,可以扩展到面向用户的信息架构。架构需要解决的问题是扩展性,可用性,性能,安全几个关键问题。而架构的表达,可以文字,表格,更重要的是图片,很多情况下是以上的组合。
    2018-05-05
  • 张志佳
    架构是解决领域问题流程和结构的高度抽象,模块是流程视角的分类,组件是结构视角的分类,而框架是这个架构的一种实现(不用语言特性可能实现有差异)
    2018-05-05
  • 老徐
    架构,设计规范;框架,实现规范;module,业务逻辑层次的划分,解耦;component,一般是功能组件,复用,如果需要也可以当做module来用
    2018-05-04
  • 冯江涛
    原来理解的架构认为是为应用层实现提供基础支撑的一套规范,这其实应该算是框架的一部分功能吧,有点管中窥豹;我现在理解的架构应该是为实现系统功能整合各个模块组件,为整个系统提供骨架支撑,可能这样理解也有偏差,希望能跟着老师领悟到更多的架构知识
    2018-05-04
  • Laughing
    在我的认知中:架构偏向于系统整体的结构,包括世纪的应该怎么配合运作,可以实现更好的流程,并且具有良好的性能;而框架也是更注重于快速实现一种需求的工具或者规范,从而达到快速开发的目的,增加对业务的关注度。
    2018-05-04
  • Daniel Xu
    当看到架构一般是新人入职第一堂课,很有同感,每次都是项目经理简单的用流程图画出产品的架构,自己理解的架构是一群有着自己独特功能的模块通过数据为纽带,实现一个新的功能的结构体。里面有若干子系统。每个子系统从逻辑角度,可用性角度,稳定性角度,已集群方式呈现出来。有个问题想请教华老师,目前公有云aws在推荐serverless架构,您对这种架构怎么理解!谢谢
    2018-05-04
  • 韩博恒
    框架是规范,架构是设计,通俗而言,以盖楼为例:房子基础就是架构,图纸就是框架。不过今天进来听听华仔讲解,更深入的了解框架与架构的区别,系统与子系统、模块与组件等。作为程序员,总是逻辑和实现,很想跨出一步,深入学习架构
    2018-05-04
  • JRich
    我所理解的架构就是系统从上而下的设计,搭的一个架子,包含了系统需要的所有组件,然后只需要往里面填充业务逻辑即可。
    2018-05-04
  • 勇闯天涯
    “从逻辑的角度来拆分系统后,得到的单元就是“模块”;从物理的角度来拆分系统后,得到的单元就是“组件”。划分模块的主要目的是职责分离;划分组件的主要目的是单元复用。” 这段话豁然开朗,也是项目管理的精髓啊
    2018-05-04
  • 不在迷津
    架构是基于我们选择某个或多个框架的规则,然后在这个规则下面把我们的各个模块或者组件可复用和可组装的去实现我们的各个业务逻辑,来保证系统稳定快速运行,同时也可以方便的扩展新的业务。
    2018-05-04
  • 在路上
    我原来理解的架构就是,把一个大的业务系统,从业务的角度,按照高内聚低耦合的原则,拆分成不同的小模块,每个模块都可以作为一个微服务,然后定义不同微服务之间的接口规范。还要根据业务特点,考虑服务的技术选型,还要解决一些关键问题,比如,一致性啊,怎么进行分布式存储啊,等等问题吧
    2018-05-04
    作者回复

    这只是架构设计在可扩展性方面的应用

    2018-05-05

  • 西园公子
    我觉得框架是一种规范,让你依照这个规范来进行发挥创造,架构是指对整体项目的规划,对各种结构的构思,从而完成。
    2018-05-04
  • A2020
    框架~规范,架构~结构,这样来区分就清晰明了了。
    之前在我的印象中,我对架构的认识一个容器,能承载业务的容器,选择架构时需要根据所需业务来进行选择。
    2018-05-03
  • 留声机【玫瑰】
    以前不太懂什么框架、架构之间的区别。现在弄懂了几个概念——系统、架构、框架子系统,组件,感触颇深。个人认为,有这样的解惑平台是真心不错
    2018-05-03
  • 三军
    架构是城市规划图,框架是具体施工图,系统是各个关联的事物组成的区域(功能区),模块是所谓的工业区、科技园、大学城,组件是施工材料。
    2018-05-03
    作者回复

    框架不是施工图哦,框架是样板工程

    2018-05-03

  • 木子李
    关联即模式,规则即接口,能力即实现
    2018-05-03
  • Forrest Li
    这些概念围绕系统做的多角度拆解:系统强调功能,架构描述结构,模块与组件分别是从逻辑与物理角度的划分,而框架更像是一个工具箱,包含着根据规范实现的具体工具。
    2018-05-03
  • 有渔@蔡
    宇宙万物就是上帝编写的绝妙架构。适者生存的生物,它的身体架构是当前环境下最优的。人,和人体的每个器官都是优美的架构。
    2018-05-03
  • SHLOMA
    李老师,子系统与模块,这两个感觉很相近,都是从逻辑角度划分,对吗?
    2018-05-03
    作者回复

    都是逻辑角度,子系统的层次高一些,而且系统具备独立运行的特性

    2018-05-03

  • 淡云天
    架构是整体,框架是组件。将一系列的框架组装在一起,实现功能性需求就是架构。架构的过程更加类似于DIY,所以说架构在于选择。。。
    2018-05-02
  • Austin
    我感觉作者应该请评论区里面精彩评论的人吃饭啊,回答的好好啊,作者给出规范定义,评论区的大神们又形象的描述,想记不住都不行。。。
    2018-05-02
    作者回复

    据说极客时间会有福利😄

    2018-05-02

  • 复醉
    业务架构、产品架构、技术架构、应用架构、信息架构,这几种架构的差别是?

    个人理解业务架构更多聚焦业务功能;产品架构和应用架构比较像,对业务进行一定程度抽象,综合考虑可拓展、可复用等特性,划分系统边界、系统角色,梳理系统间关系、系统内关系;信息架构定义不太清晰;技术架构中关于系统和子系统划分、模块划分、概念定义是否需要与产品架构统一,这个比较困惑,各有利弊。
    2018-05-02
  • 王小强·Steven
    如果物理属性是组件的必备属性,那么很多组件都不具备。一般谈起组件,都是强调它的业务无关性和可重用,自包含也更多是指功能自包含,而非物理部署的自包含。所以把物理作为组件的必备属性,不敢苟同,也望解惑?
    2018-05-02
  • 老王
    我之前所理解的架构是:代码是如何组织的?比如一个新人刚加入项目组,他总是想搞清楚代码结构,然而由于经验有限,总是不得要领,如果编码能力也差的话,就会受困于各种细节,这样就会只见树木不见森林。架构设计只所以需要很多年才能掌握,是不是因为新人总是在森林里面走,而没有机会去规划一片森林呢?
    2018-05-02
  • 夏天39度
    框架用来定义规范简化开发,一定层度上能提高开发效率。架构是一个整体设计概念,架构决定了系统的瓶颈。
    2018-05-02
  • ncicheng
    架构设计就是体系结构设计,DoDAF也是一种架构设计方法,一般是采用多视图的方式描述复杂系统。
    框架是规范的具体实现,不是唯一的。
    2018-05-02
  • 飞龙在天
    我理解的架构是,在一定的环境下,让系统满足特定功能与非功能需求的方式方法。
    2018-05-02
  • 123
    我理解的架构,从0到1的过程,包括定义规则,定义运作方式。而框架和你的认知一样,是一种规范
    2018-05-01
  • 汪恒伟
    架构有业务,有功能分工,对于产品研发而言,架构应该是最先确定的,系统+子系统+中间件=架构,而框架,我更多的还是从开发角度去理解,框架是为了更好的开发,而定义的一种约定。
    2018-05-01
  • 小浩子
    讲得非常好,指点迷津的感觉。个人理解,这些概念都可以从物理角度和逻辑角度来看待,在不同的语境中使用不同的术语。架构是一个高层次的综合体,也是老师提出“顶层结构”的意义,其不仅仅是一种实现方式和规范,还包含了理念和方法论。有一点疑问,“模式”相较于文中提及的几个概念是什么样的定义和关系?
    2018-05-01
    作者回复

    模式就是某类相似问题的共同解决方案,简单来说就是套路

    2018-05-02

  • 无名
    模糊的概念有些许清晰
    2018-05-01
  • 千年准一会
    我理解的架构,应该是描述系统内有多少个子系统,子系统又由什么模块组成,描述需要多细的程度,就看系统的复杂度了
    2018-05-01
  • 于宏亮
    我的理解:架构是思想,是抽象的。框架是实现架构的工具,有使用规范和说明,是具体的。
    2018-05-01
  • 不记年
    系统是个体的组合,系统内个体遵循定义好的规则运作,使系统可以展现出特有的能力,这个能力是系统内单独个体所不具有的。
    子系统是对系统在业务角度上的分割,子系统具备系统也是一个系统。
    模块和子系统的概念相似,个人认为更多的是语义上的区别,子系统的概念更大一些。对子系统的划分可以称之为模块。
    组件和框架,都是从实现角度上看的不同程度的复用。框架是实现基本的功能(多少控制),供人往里填业务。而组件可以直接拿来就用。
    架构,对系统,子系统,模块划分。框架,组件的选择的描述
    2018-05-01
  • 丶Zero灬
    原来理解的架构只包含了模块和组件,更关注功能(或者说看得见的)忽略了规则各部门的协作(看不见的)。
    2018-04-30
  • 1024
    架构,类似于体系结构(系统结构),都是Architecture,是顶层设计,前者为软件,后者为硬件。
    2018-04-30
  • 紫荆王朝
    架构是对系统进行追求合理的一种梳理划分,就像秦始皇划分天下三十六个郡为了更好的治理(模块化),用对应行政机构进行管理(组件)。就像更为早期实行诸侯分封制进行模块化,架构是为了系统的最优设计
    2018-04-30
  • oracle3
    架构一般先从物理层面分层,再从逻辑层面分模块,再用mvc,mvp这些框架规范开发,几个方面的集成才是完整的架构,不知道这个观点对不对?
    2018-04-30
  • 风继续吹
    模块更多从业务功能方面切分,组件更多从技术方面切分(我理解为函数的另一种叫法),如加密组件、通讯组件等,达到技术编程的可复用性~
    2018-04-30
  • BearyW
    我一直的想法就是,架构是需要设计的,设计各子系统,模块之间的关系。而框架的关系是已经固定的,主要是应用上去。
    2018-04-30
  • fish007
    以汽车为例讲解可能更容易理解,整体-系统,功能-模块,组件-零件,架构-内部结构,框架-可复用结构,对吗?
    2018-04-30
  • 任锋
    非常感谢华仔的回复,看到您的回复,简直醍醐灌顶,对于开发来说,很少知道物理结构是什么样的,比如我们所了解到我们网站的物理结构,首先是web服务 用的nginx(具体多少台服务器 不太清楚)存储用的mysql集群 一主多从 (也不知道有多少台服务器,运维说我们连接的是代理地址 后面会平均分配到各个存储服务器上去) redis缓存集群用的是rediscluster. (12台服务器)😄 软件架构后面在自己梳理一下。非常希望能加您的微信 renf_cd.
    2018-04-30
  • YEROM
    软件架构我觉得基本就是你讲的内容。不过其他部分,比如业务架构、数据架构、安全架构等,也是更大的一个架构范畴。如果中小公司,这些架构可以包含到软件架构里,没有太大影响,但是大型公司就不一样了。
    2018-04-29
    作者回复

    数据架构,业务架构,安全架构都是架构的一类,只是从不同的角度观察系统而已,通常情况下不太可能用一个架构就能够涵盖所有的角度

    2018-04-29

  • 江南皮革厂研发中心保安队长
    受教了,概念虽然不是我们需要钻牛角尖的点,但是需要在实践和案例中正确地回归概念,这样才能有更好的视角去理解新知识和新技术!
    2018-04-29
    作者回复

    名正才能言顺,否则一堆人聊的很开心,结果大家说的都不是同一个东西,那就没有意义了

    2018-04-29

  • phoneone
    架构是针对系统来说的,这个系统包括系统的子系统;指明系统有什么,该怎么运作;如何划分层次!
    2018-04-29
  • phoneone
    架构是针对系统来说的,这个系统包括系统的子系统;指明系统有什么,该怎么运作;如何划分层次!
    2018-04-29
  • caiyun
    架构分为系统架构和软件架构;框架是系统的半成品,将共通处理在框架中实现,提高开发效率和品质;一定程度上软件架构类似等于框架;模块是从业务逻辑层面进行的划分;组件是与业务逻辑无关的共通处理的实现。四者交织在一起,构成系统开发的基石。
    2018-04-29
    作者回复

    框架理解为半成品不太好,理解为模具更好一点,软件架构也不等于框架,组件与业务逻辑也是有关系的

    2018-04-29

  • Tom
    我所理解的架构:
    架构是系统的基础结构。各层面上,结构体现为顶级单元以及他们之间的关联关系。
    • 逻辑层面上,最终用户看到的功能集,功能由哪些子系统、顶级模块等逻辑单元,以及关联关系组成。
    • 开发层面上,程序员怎么实现,所看到的子系统、包图、框架、类库以及总体代码结构。
    • 物理层面上,系统运维工程师要部署哪些组件、组件的拓扑结构,可部署单元有:Nginx/web server/db/cache/mq等等各种用途的单元。
    • 运行层面上,是系统处理及通讯的动态过程,运行性能、并发、分布式情况。
    2018-04-29
    作者回复

    这个就是4+1视图的观点,但实际应用过程中,很少每次都全部画出来,而且这是描述方法,不是设计方法

    2018-04-29

  • 张玮(大圣)
    另外补充下:其实朗读的同学技术名词发音是对的,只是长期读错的我们没搞对哈,

    多谢运华做的这个分享,提个意见:能否再把一些原理说的更易懂,再次提炼,可能对我们理解的知识又是一个升级!
    2018-04-29
    作者回复

    这已经是我见过的最易懂的呢😂
    俗话说师傅领进门,修行靠个人,我主要还是提炼核心和关键点,更多细节还需要自己体会,当然随着后面的章节逐步展开,也许很多疑问也就慢慢解决了

    2018-04-30

  • 张玮(大圣)
    框架,framework 人们长期解决一类问题形成的一种固定功能工具

    架构,architecture 如何让组成部分按既定规则,要求工作,可以借助框架,当没有类似框架时,需要自力更生
    2018-04-29
  • 卫江
    架构是抽象的思想和设计,框架是具体的一些实现!
    2018-04-29
  • 东风
    框架:是简答题;
    架构:是命题作文;
    2018-04-29
  • 胖胖的程序猿
    本人是做Java后台开发,从后台服务理解的架构: 从业务角度去进行系统拆分,拆分成多个子系统独立部署,子系统之间利用框架如 dubbo,hsf,springcloud,mq消息等框架来进行交互,,每个子系统内部实现又按照一些功能的划分进行分割模块,每个子系统可能有自己的数据库和表,按照mvc和一些设计模式来是实现功能,必要时用到redis缓存一些高频数据,再利用nginx负载均衡,集群等技术保证一些可用性。听起来更多像是一些技术的堆砌。
    2018-04-29
  • 微笑的向日葵
    系统是产品,比如微信是一个社交产品;
    架构是有效合理的整合子系统,如用户子系统,支付子系统等等,由于微信比较复杂是一个多机系统,一般的办公系统是单机系统用它的开发框架表示也可以;
    子系统是各个模块和组件为了实现子系统的业务功能如登录功能就有登录组件,oauth2授权组件等
    组件和模块都是子系统的功能单元
    2018-04-29
  • 周龙亭
    我理解的架构首先是对业务系统的抽象,把具体的业务系统用技术的手段表达出来。把整体系统拆分成一个个子系统,定义子系统之间的交互方式。然后做技术上的选型,开发语言,开发框架,数据库,缓存等的选择。
    2018-04-29
    作者回复

    这是典型的业务架构,中间件,基础软件就不能这么理解,例如mysql的架构

    2018-04-30

  • focusOn
    架构和框架没有直接关系,架构的目的是以一个大局观的角度去考虑,寻找最优解!框架只是实现你架构的一种技术选型。
    2018-04-29
  • darkleo
    架构是结构,业务上得逻辑拆分结构,物理上得结构,代码实现里的结构。
    框架则是规范,标准。
    模块:业务的逻辑拆分。模块也可以当组件来开发。
    组件:物理的拆分,可插拔。
    2018-04-29
  • 清泉
    架构是用来描述系统结构的。它明确了系统里应该有哪些个体,以及这些个体之间按照什么规则协作。架构在描述系统上有多个视角,可以是业务逻辑上的、物理部署上的以及开发规范上的等
    2018-04-29
  • 天天向上卡索
    架构包括物理架构和逻辑架构,物理架构一般是指机房,网络,服务器等方面的架构,逻辑机构一般指业务架构,系统如何划分为对应子系统,逻辑上由哪些子系统及模块组成。
    系统和子系统感觉有时候没有明确的界限,有可能一个系统也是另一个系统的子系统,但对于系统内内部各部分而言又算是一个系统,不知道是不是这样,还请多多指教
    2018-04-29
    作者回复

    系统和子系统类似一个俄罗斯套娃,可以分多层,下层的系统是上层的子系统

    2018-04-30

  • “其次,系统中的个体需要“根据某种规则”运作,架构需要明确个体运作和协作的规则。”
    我猜华哥这里的“架构”应该是“框架”😝
    2018-04-29
    作者回复

    没错,就是“架构”,架构需要明确规则,框架也要明确规则

    2018-04-30

  • LRG-
    我理解架构有点像化学中原子构成分子,达到一种稳定的状态,原子不同的空间排列方式出来的分子就有不同的特性。框架是套规范,符合规定的特性就可以说用了那个框架,框架可以迭代细化下去,spring是基于DI框架,通用注册系统基于spring框架...
    2018-04-29
  • 任锋
    希望老师能给一张架构图看看,看了这篇文章我理解感觉又不太理解,因为顶层结构,我想知道架构图怎么画。有没有真实系统案例分享一下。谢谢🙏
    2018-04-29
    作者回复

    图中的图都是架构图,只是比较简单,麻雀虽小五脏俱全😄

    2018-04-30

  • 任锋
    您好 华仔,我理解的架构是两种,第一从软件结构来分,第二从物理结构方面分。面试 一般问你们网站是什么架构?我是不是应该从软件结构方面来回答呢?
    2018-04-29
    作者回复

    面试最好都讲,有的面试官对物理结构比较关注,有的对逻辑结构比较关注

    2018-04-30

  • 沉默的雪人
    架构就是一个软件系统的顶层结构,我原来就是这么理解的。
    2018-04-29
  • tomsong2018
    字面理解框架,搭建架子,重复造轮子。架构就是这个架子里面主要有什么。
    2018-04-29
  • 刘畅
    我理解的架构是:描述组成整个系统的个体,以及个体之间的关系。
    2018-04-29
  • 青色烟雨
    模块是逻辑维度,组件物理维度划分
    2018-04-29
  • YunliangChen
    传统的架构和微服务架构有什么区别和联系
    2018-04-28
    作者回复

    欲知后事如何,请听后面分解

    2018-04-30

  • 张小洋
    我理解的,系统是为了满足一系列业务需求的,能work的系统不难做,但是work的很好的系统不容易,尤其是随着需求的变化,如何保证系统能work且持续work,甚至能指引需求给需求更大的空间。

    老师提到了规范,我想规范就是那保证系统不畸形的良药,但是如何设计规范,希望能听到业务、技术等方面的建议。尤其是作为技术从业者,如何和产品、运营等角色协作好,既能满足需求,又能有所沉淀。
    2018-04-28
  • 陈奇
    架构就是系统的说明书。架构也指构架系统的能力。不过我最以为然的定义是,架构是业务和技术实现之间的桥梁。
    2018-04-28
  • 苏本东
    我的理解是:框架确定工程实施标准,不能超出框架规定的框框;架构确定整个工程的构成部分和他们之间的协作关系。框架内敛,架构外放。
    2018-04-28
  • Panda
    框架是图纸 组件是建材
    2018-04-28
  • Tom
    一、先来说下子系统与模块
    为什么是子系统而不是模块呢?两者的关系与区别?
    1、逻辑视角上,都是逻辑单元,子系统是更高一级的逻辑单元,子系统是模块的集合,系统是子系统、模块的集合。
    子系统内部各模块间比子系统外的模块有更高的内聚,这是划分子系统主要因素。
    2、物理视图上,子系统是可部署组件,模块不是可部署组件。子系统、系统可以只包含一个模块。

    我的理解如上,如有误感谢指正一下,谢谢!
    2018-04-28
  • 何俊南
    我觉得架构就是通过抽象的概念把一个大规模的系统的一些共同点提炼出来形成一个个子系统,一个个子系统再细分成很多模块,慢慢的到一个个职责单一的接口和实现多个接口的业务。
    2018-04-28
  • amy
    架构从上到下开始设计系统,子系统,模块等,选择合适的框架,组件,使各个模块能组合成功能正常的子系统,再把子系统组合成系统
    2018-04-28
  • ericzx
    原来理解的架构比较狭隘,更多从代码的设计上考虑。只要我的设计实现能够应对需求的不断变化,而不用或很少修改代码,就是一个好的架构。读完文章后,现在的理解是架构对业务的需求进行划分,整体上定义一个顶层系统,再拆分实现不同需求的子系统。再对每个子系统从逻辑上进行功能模块的划分,物理上根据业务特点进行组件的选取,然后从规范上选取技术框架。最后根据某些规则进行系统的关联。完成整个系统的架构。
    2018-04-28
  • dDDbbD
    我理解框架是说我们可以在承重墙和柱子构建的框中搭建我们的房间,强调的是框的范围功能;架构是说我们从房间的功能考虑柱子和墙及搭建的结构,强调的是结构关系。
    2018-04-28
  • 叔鱼
    谢谢华哥。听了分享之后对系统和框架的理解深入了很多。我之前理解的架构,这里特指软件系统的架构,就是:为了提供某种能力,你设计了一套系统,这个系统有内部多个提供不同功能的模块协作组成,而架构就是:你选择了(开发了)哪些特定功能的模块,这些模块分别完成什么职责,你把这些模块『架』在这个系统的什么位置,他们之间怎么交互协作和分工,通过把这些模块『架』在不同的位置形成了一种结构,并定义这些模块之间交互协作的规则,从而形成一个能给你提供目标能力的系统。
    2018-04-28
  • 娟子
    以前觉得架构很高大上,觉得很难学,读了老师的文章,对架构的概念了解,一直觉得架构是各个模块组合而成的
    2018-04-28
  • 平头哥
    架构关注的是大的架子,框架是针对架子的某个地方的实现
    2018-04-28
  • 亚林
    架构是抽象性的思想,框架是对架构的实现;系统,子系统都是对业务的抽象分解确定;模块更是从业务上面的分解和技术功能上面的定义,模块是从具体技术的落地方案。
    2018-04-28
  • 加油
    老师,感觉目前好多加厚文章和公司架构都是各种流行技术堆砌,对于新人如何入门
    2018-04-28
  • 王旭东
    架构由基础结构替换为顶层结构,这里的顶层结构是不是也应该有划分,比如整个业务系统有顶层结构,存储系统也有顶层结构,整体在一起也有顶层结构。

    我理解的框架就是就是一种标准或者规范,一种技术手段,相对更偏向业务系统层面。
    架构是一种结构,定义系统整体结构,我理解就像要建一所学校,架构就是设计图纸。

    从大的方向上感觉架构是包含框架的,但是从小了说框架里好像又包含架构…
    2018-04-28
  • 绿鲤鱼与驴。
    架构是模块与模块,系统与系统的完美结合,达到最好的效果。这样理解对吗?老师
    2018-04-28
  • 九脉一谷
    我理解的架构从业务功能划分需要包含哪些功能模块,基于这些功能模块需要考虑选型什么样的框架和组件来支撑业务功能。
    2018-04-28
  • Leo Bright
    原来理解的架构:一个庞大复杂系统下各个部件(子系统、模块)的组织关联关系。两个部件之间的特定组织关系即这样设计的考虑、出发点,就是架构的设计原理。
    2018-04-28
  • 影浅
    其实我一直的理解里,框架和架构没硬性的关系连接,框架只是实现一套系统的一种板砖,架构就是把他们串联起来的一种规则约定😿,不过组件与模块看来我的理解一直是对的
    2018-04-28
    作者回复

    严格意义来说,框架还不是板砖,而是板砖模具;架构也不是将框架串起来的约定,架构中可以没有框架

    2018-04-28

  • DeathKnightH
    原来理解的架构:比较片面,简单来说就是系统分了哪几个模块,每个模块里面代码是如何分层,如何组织到一起,没有整体的观念。

    现在理解的架构:软件系统的顶层结构,以囊括整个软件系统的角度看,架构需要描述系统的组成,包括所有的子系统以及组成系统的“个体”,还要定义“个体”之间的交互规则。
    2018-04-28
  • qqp
    这个描述我认为最合适:架构描述了系统的静态结构和动态行为,系统元素,元素外部属性,以及元素间的关联关系。
    2018-04-28
    作者回复

    描述没错,但比较容易与面向对象混淆,另外,系统的静态结构和元素的粒度和层级需要明确,否则微信有架构,微信登录系统也有架构,很多人会混淆

    2018-04-28

  • Lave
    我之前理解的架构是一套业务系统的完整解决方案。而现在对架构的理解更加明晰了。现在流行说全栈工程师,全栈工程师可以从不同纬度看问题,提出各种解决方案,我觉得就是架构师。
    2018-04-28
    作者回复

    前端可以有架构,后端也有架构,合起来又是一个大架构,所以全栈工程师不等于架构师,但架构师确实要在横向技术方面都有一定的积累才能更好的进行架构设计

    2018-04-28

  • 小飞哥 ‍超級會員
    我认为架构是分层,系统是每个分层的模块。而系统的业务又可以分模块,每个模块是功能的集合。现在好多人说功能模块化,就是把功能再次细分!
    2018-04-28
    作者回复

    分层是常见的架构设计方式,但并不一定每个架构都是分层架构,例如微信的业务顶层架构,是按照逻辑分类的,分为朋友圈,摇一摇,聊天,支付等,并不存在明显的层次关系

    2018-04-28

  • marvel
    架构是描述逻辑组件之间,物理组件之间的关系,框架是描述开发、运维约定的规范
    2018-04-28
  • 笑地
    我原来理解架构像是人体的物理组成(头、手)和虚拟组成(消化系统、神经系统)
    2018-04-28
  • 不過勝負
    背景需要+目标实现效果来诠释架构。
    2018-04-28
  • 不過勝負
    三角形具有稳定性;那么,三角形在某些领域或场景下,它就是一种架构。
    2018-04-28
  • 吴传卜
    框架关注的是“规范”,架构关注的是“结构”
    2018-04-28
  • 文兵
    我理解的框架就是spring hibernet之类的,架构就是这些框架的整合
    2018-04-28
    作者回复

    架构不等于框架的整合,我们很多系统都不用框架的😂

    2018-04-28

  • 文兵
    我理解的框架就是spring hibernet之类的,架构就是这些框架的整合
    2018-04-28
  • yeshu🏂
    架构是建造楼房的钢筋结构,确认好户型,有哪些房间,房间用途,对应着业务有哪些,业务代码放在哪。mvc等框架是室内设计,确认布线,家具摆放,对应的是业务具体实现代码,怎么写,放在哪。
    2018-04-28
  • 麦子
    之前理解的架构是比如我要做一个管理系统 然后从前台到后台都用什么框架 至于模块什么的都没有考虑
    2018-04-28
  • mm23504570
    我之前理解的架构是指系统之间有哪些逻辑架构,各个逻辑结构是怎么交互。 最后每个模块用什么物理组件去实现。
    2018-04-28
  • 王虹凯
    架构,
    之前的理解:就是技术栈,忽略了整体结构这个概念。
    现在的理解:架构其实是从整体来看一个系统,他的各个业务功能组成部分是定制的业务模块还是成熟的组件。
    我感觉差异是:感觉之前理解的不具有系统性,属于‘野路子’,只是开发生涯中的积累,现在把概念系统性的补了一下。有种顺畅的感觉!
    2018-04-28
  • 星火燎原
    我的经验是所谓架构是在深刻理解业务基础上,以完成整个系统业务功能为目标,且具有扩展能力的基础结构。
    2018-04-28
    作者回复

    这个理解一般适应于业务系统开发,例如ERP,运营系统等,其主要特点是业务复杂多变,可扩展要求高,对高性能高可用要求不高。

    2018-04-28

  • 小柯
    微服务,整个系统的架构由各个子系统共同组成,每个独立的子系统的架构指的是具体的数据模型设计、提供的接口(子系统的提供的服务)、调用的服务(与其他子系统的调度),已经采用的技术栈、组件等,过子系统的架构评审,主要也是过以上几点,有时候还会讨论具体子系统的边界问题。愚见,求指正。
    2018-04-28
    作者回复

    微服务是一种架构设计方法,适应于业务领域,但不等于架构本身,例如redis本身也是有架构的,不会把redis用微服务的方式实现

    2018-04-28

  • 王维
    从不同的角度来描写软件的结构,就是架构
    2018-04-28
  • Kyle
    我以前理解的架构是这样的:它是一个系统全局的概念,它用来描述系统实现的具体物理组织以及各个组织之间的关联关系。我以前觉得要理解业务逻辑的话还是画用例图好些,像大佬提到的逻辑层次上的架构我觉得似乎无益于业务逻辑的理解,因为业务逻辑是个“流程性”的东西,所以从未想到过还有这层面的架构。
    2018-04-28
  • 纯爷们
    架构是站在宏观上来定义的。框架相对来说小一层。系统子系统也理解的差不多。但是自己说不出来,😅
    2018-04-28
  • Tony🐑
    我之前理解的架构是指:系统的分层,全局异常处理,负载均衡策略这些所有相关的东西。
    2018-04-28
  • 凌霄
    还是太抽象,名次定义
    2018-04-28
  • 马克
    此次是第一次明确的接触架构领域,工作当中虽然有涉及,但是没有明确的概念。以前对架构的概念很模糊,理解为模块和功能的组合,也构思过怎样设计一个高性能,可扩展的架构,但是实现很难,基础不扎实。希望此次能够在李老师的讲解下,满载而归。
    2018-04-28
  • stevensafin
    系统与子系统的理解这个比较正确,与作者理解相同,组件与模块一直没有理解到组件的真谛,通过作者的文章,有了一定理解,感觉还是不够透彻,框架与架构我理解是框架是架构的实现架构的一种工具
    2018-04-28
  • 癸亥
    之前没有4+1视图的概念,工作中单独的画过软件架构图和硬件部署架构图,并没有认识到它们之间应该是有关联的。
    2018-04-28
  • 李志博
    读到最后,也就是说,架构是一个大系统下的一级子系统之间如何协作?
    2018-04-28
  • 刘亚维
    个人理解的架构是一个软件整体的结构和各职能模块(完成不同类型业务的组件)之间的调用关系。框架是指由外部或者内部实现的种能够提供特定功能的软件或者组件。
    2018-04-28
  • void
    开源中间件的选择,语言选择,比如用Java还是pathon还是go,性能优化,开发基础组件
    2018-04-28
  • cuiz1688
    对这些概念的解读很透彻
    2018-04-28
  • 武坤
    我以前对这些概念很模糊,尤其是模块和组件,说不出其中的区别。老师讲得很清晰,首先明确“概念”,后面才能避免模糊。
    2018-04-28
  • ikel
    我以前认为架构就是框架
    2018-04-28
  • 天晴
    哥,我还在框架层面,得加油了
    2018-04-28
  • 鲁大师
    咱们这个课应该是架构师扫盲课,大家的志向如果是想成为架构师,还是得结合课程自己多努力。
    2018-04-28
  • 特特
    框架更加具体,更偏向于技术,比如spring,而架构是系统的体系结构比如mvc架构
    2018-04-28
  • anchor
    之前理解的架构就是定义软件的规范,看了此文对这个规范的内容理解更深更具体了 包含什么 按什么维度 站在哪个层次等
    2018-04-28
  • 合民
    您好,看了您的文章,发现我之前理解的架构更多是框架层,而没有上升到架构层面。比如一个项目由几个子系统组成,某个系统由负载层,nignx层,springboot,mysql组成。我想问下,架构和框架的“边界”如何把握,避免过度设计
    2018-04-28
  • huazsh
    之前所理解的系统架构就是说由哪些业务模块组成以及之间的关联调用关系
    2018-04-28
  • Maiza
    某某大神说过,架构即职责分离 😀
    2018-04-28
  • 闻人
    发现一直以来对架构的认识不深,单单以为架构就是Nginx、Tomcat、MySQL,Redis这些东西组成的产物
    2018-04-28
  • MyKings
    我的理解:

    架构是为了解决某个或某种问题而编写的“图表”方案,该方案按照不同纬度(如:业务纬度,开发纬度,物理纬度)的需求展开设计,并保证由该方案完成的系统可稳定运行并可容易扩展。
    2018-04-28
  • 猎人
    架构描述系统内部以及系统之间的关系,框架描述的是一套规则和约束,一个架构里面有很多种关联的框架
    2018-04-28
  • 郭涛
    架构是指软件系统的顶层结构,那就是说不存在子系统的架构师了吗。
    2018-04-28
  • 壹个人的浆糊
    原来理解架构只是软件层面上的,物理层面的没想过
    2018-04-28
  • jason
    类比其他行业,架构一词也会用到,它描述一个系统的组成部分的结构,相互作用关系。软件系统架构也比较类似,不过它有特定的一些东西,比如框架,组件等。!
    2018-04-28
  • jeanne
    原来理解的架构更像系统和子系统的关系,从开发角度来看,更像是模块和层级。
    2018-04-28
  • 之前的理解是:软件系统中的各个组成部分直接的关系。
    2018-04-28