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

    作者回复: 精炼!

    
     1347
  • 每天都在找小黄车
    2018-04-28
    搬砖的:“头,我们要造什么?”;(做什么系统?)

    工程师:“龙之梦商城”;(XXX系统,比如微博系统)

    搬砖的:“图纸画出来了嘛?”;(架构是怎么设计的?)

    工程师:“一楼主要以女性消费为主体、二楼以大众娱乐为主体、三楼以美食为主体”;(相当于微博系统中的各个子系统,比如评论子系统、动态子系统、消息子系统)

    搬砖的:“头,说人话”;

    工程师:“一楼有卖衣服、化妆品的,二楼有唱歌、看电影的,三楼有吃的”;(【模块】按照逻辑区分,比如存储数据模块、搜索模块、消息推送模块)

    搬砖的:“有没有很知名的店啊?”;

    工程师:“有的,一楼有香奈儿、优衣库...、二楼有好乐迪、万达影院....、三楼有海底捞、避风塘.....”;(【组件】按照物理区分,存储数据模块对应Mysql、搜索模块对应ElasticSearch、 消息推送模块对应Kafka)

    搬砖的:“对了,头,商城大门有啥需要叮嘱的施工规范不?或有啥简化施工工艺的新技术嘛?”;(有框架的可以用吗?)

    工程师猛吸了一口烟,把烟头扔在地上,用皮鞋左右撵了两下,缓缓从嘴里崩出四个字。
    “老样子吧”。(Spring全家桶甩起来)
    展开

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

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

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

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

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

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

    作者回复: 提炼了精华,赞

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

    作者回复: 很形象😂

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

    作者回复: 点赞

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

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

    
     9
  • 今夕是何年
    2018-05-01
    架构是顶层设计,框架是具体实现。
    
     7
  • CHaNniNG
    2018-04-28
    关于华仔的思考题,本人刚刚接触架构,之前作为开发人员理解的架构不是很深入,基本是按照各个技术组件的组合方式来理解的,架构做得好不好,主要看技术组件能否组合得好,并满足业务特性;今天听了华仔的讲解,发现我之前忽略的业务模块的组成这一方面而单单考虑技术点了,架构其实是可以从多个角度来进行阐述的。华仔的讲解让我对架构的概念有了更加清晰和全面的了解,谢谢华仔
    
     7
  • feiyue
    2018-04-28
    大道至简。架构是宏观整体,框架是微观组成。
    
     7
  • Joker
    2018-05-22
    是不是可以这么认为,就是做架构就是对于解决一个或者一类问题,构建一个系统,你需要为这个系统根据业务划分模块,需要加入能组合起来的组件和框架,然后你需要构建一系列规则,让这些组件和框架跑起来,各自发挥各自的能力,来实现一个个模块,然后这些模块又组合起来成了整个系统,所以做架构需要很熟悉业务,会业务逻辑划分,要熟悉很多框架,组件,知道他们的能力,熟悉怎么组合他们完美的运作起来!

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

    
     6
  • felix
    2018-04-28
    之前理解的架构就包含2部分,逻辑架构和物理架构,现在知道了还有开发架构
    
     6
  • 线条
    2018-06-24
    系统根据业务或功能划分为各个模块,某些模块可能又被升级为子系统; 模块中可能使用了很多组件来实现某些具体功能 ; 同时,也可能使用了某些框架来作为开发的基础,而架构则描述了各个子系统或模块间如何协调工作。不知这么理解合理不?

    作者回复: 理解正确

    
     5
  • Suclogger
    2018-04-28
    我觉得架构的定义也可以从逻辑和物理上拆分,从逻辑视角出发,可以认为是业务的各个模块的定义,从物理视角出发,可以认为是各个模块的实现之间是一一种什么方式交互合作。感谢作者的精彩分享,就是演讲者对专有单词的读音还要改善,比如nginx。
    
     4
  • 理想
    2018-04-28
    我理解的架构,是通过不同分工合作和识别不同生命周期为了一个组织或特定的目的而形成的树状结构,这种结构有利于在有限的时间内使组织内的角色完成相关的工作,从而达到业务增长的目的。而作者的这个架构应该更多地理解为软件架构,但是局限在顶层是否合适,还要看后续的文章内容阐述。
    
     4
  • Ken
    2018-04-28
    系统架构主要描述一个系统有哪些子系统构成,每个子系统的职责,以及子系统之间如何交互。
    从技术角度来说,系统架构也会描述系统的技术栈,技术选型,以及高层次的业务流程。

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

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

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

    
     3
  • 弄花香满衣
    2018-04-28
    我理解的架构包括网络、机房、存储、容器、系统实现;其中系统实现约等于框架,比如经常用的MVC框架、redis、RPC等等
    
     3
我们在线,来聊聊吧