1.软件架构编年史(译)

原文:https://herbertograca.com/2017/07/03/the-software-architecture-chronicles/

译者:最早看到的是作者的这篇文章(译文),其中的那副信息图可谓集软件架构之大成。后来发现这是作者学习和思考软件架构发展史的系列文章之一。“以史为鉴,可以知兴替”,阅读历史就是学习的过程。翻译也不例外,我也是通过阅读和翻译来学习软件开发的历史,联系作者获得授权之后便有了这一系列译文。

这是软件架构系列的第一篇文章。我将我对软件架构的学习过程和思考以及我是如何运用这些知识的写成这一系列文章。

我把这一系列文章称为“软件架构编年史”,并不是因为我觉得自己的文笔不错,而是想用一种有趣的方式旧调重弹!😀

在第一篇文章里,我将谈谈我撰写这一系列的原因和接下来的计划。

学习历史的重要性

不学习历史的人注定要重复错误。——温斯顿.丘吉尔

我发现从历史中学习十分重要,历史可以教给我们很多东西。在个人层面,我们(最终有望)从自己的失败中学习。在国家层面,历史帮助形成我们的文化,创造群体思想,“我们”的思想,国家的同一性。它还能帮助我们从祖先的错误中学习,比如错信一些人的疯狂思想,想想第二次世界大战...

对我们开发者来说,历史帮助我们在前辈们的知识上前进。它帮助我们从前辈们的知识:错误、经历和经验中学习。它帮助我们“站在巨人的肩膀上”更上一层楼!

在我向更好开发者前进的成长之路上,我浏览过许多文章,观看过许多会议演讲,也阅读过许多书籍。我尽可能地站在巨人的肩膀上!

然而我一直有一个困惑,这些观点发展出其它许多观点,又继续发展出更多的观点...这就好比“传话游戏”,论文、文章或者书籍原本要表达的思想最后终会被扭曲。

于是我开始在互联网上淘宝,寻找表达这些概念的原始论文、文章和书籍,我觉得它们是我工作中最重要的概念,我自己也时常思考它们。

在我尝试以某种考古方式理解这些概念如何形成的过程中,我的思考就形成了这一系列文章。

撰写这些文章强迫我大量阅读和思考这些主题,这帮我理解现代软件开发中使用的技术。我希望这些文章内帮到更多后来的开发者。

然而,如果你读到任何不理解或者有异议的内容,请让我知晓。我对这些主题的讨论持完全开放的态度,希望可以从他人那里学习,当我被证明犯错时我会改变我的观点。

软件架构编年史系列

  1. 软件架构编年史(译) //原文
  2. 软件架构预述(译) //原文
  3. 编程语言的演化(译) //原文
  4. 架构风格 vs. 架构模式 vs. 设计模式(译) //原文
  5. 单体架构(译) //原文
  6. 分层架构(译) //原文
  7. MVC 及其变种(译) //原文
  8. EBI 架构(译) //原文
  9. 包与命名空间(译) //原文
  10. 领域驱动设计(译) //原文
  11. 端口和适配器架构(六边形架构)(译) //原文
  12. 洋葱架构(译) //原文
  13. 整洁架构(译) //原文
  14. 事件驱动的架构(译) //原文
  15. 从 CQS 到 CQRS(译) //原文
  16. 面向服务的架构(SOA)(译) //原文
  17. 清晰架构(01):融合 DDD、洋葱架构、整洁架构、CQRS...(译) //原文
  18. 清晰架构(02):超越同心圆分层 (译) //原文
  19. 清晰架构(03):在代码中展现架构和领域 (译) //原文
  20. 清晰架构(04):用文档描述架构 (译) //原文
  21. 一个项目的演进:从 MVP 到 P
  22. 4 + 1 架构视图模型
  23. 架构的质量属性

时间线

下面是我在阅读所有这些主题的文章和书籍之后总结的一条软件开发发展的粗略的时间线。我找到的关于确切时间的参考资料都作为链接加入了时间线,拿不准的时间我都加上了“~”,表示“大约”是这个时间。我们还可以在维基百科的编程范式主页上找到大量相关的内容。

这里列出的大多数话题都将在这个系列中谈及。

  • 20 世纪 50 年代
    • 非结构化编程
    • ~1951 – 汇编
  • 20 世纪 60 年代
    • 结构化编程
    • 分层: 用户界面、业务逻辑数据存储都在一层
    • ~1958 – Algol
  • 20 世纪 70 年代
    • 过程式/函数式编程
    • ~1970 – Pascal
    • ~1972 – C
    • 1979MVC 模式(Model-View-Controller)
  • 20 世纪 80 年代
    • 面向对象编程 (但其思想在 20 世纪 60 年代晚期已经第一次提出)
    • 分层: 两层,第一层是用户界面,第二层是业务逻辑和数据存储
    • ~1980 – C++
    • CORBA – 通用物件请求代理架构(尽管1991年才推出第一个稳定版,但最早使用可以追溯到 20 世纪 80 年代)
    • ~1986 – Erlang
    • ~1987 – Perl
    • 1987 – PAC 即 HMVC 模式(Hierarchical Model-View-Controller)
    • 1988LSP(里氏替换原则) (~SOLID)
  • 20 世纪 90 年代
    • 分层: 三层,第一层是用户界面,第二层是业务逻辑(以及浏览器作为客户端时的用户界面展现逻辑),第三层是数据存储
    • ~1991 – 消息总线
    • ~1991 – Python
    • 1992EBI 架构(Entity-Boundary-Interactor) 即 EBC 或 EIC
    • ~1993 – Ruby
    • ~1995 – Delphi, Java, Javascript, PHP
    • 1996MVP 模式(Model-View-Presenter)
    • 1996OCP, ISP, DIP (~SOLID), REP, CRP, CCP, ADP
    • 1997 – SDP, SAP
    • ~1997面向方面编程
    • ~1997 – Web 服务
    • ~1997ESB – 企业服务总线 (尽管创造该术语的书籍2004年才出版,但这个概念早已被使用)
  • 21 世纪 00 年代
    • 2002SRP (~SOLID)
    • 2003领域驱动设计
    • 2005MVVM 模式(Model-View-ViewModel)
    • 2005端口和适配器架构即六边形架构
    • 2006? – CQRS 与 ES (命令查询职责分离与事件溯源)
    • 2008洋葱架构
    • 2009微服务(Netflix)
  • 21 世纪 10 年代
    • 2010DCI 架构(Data-Context-Interaction)
    • 2012整洁架构
    • 2014 – C4 模型

译者注:C4模型的介绍可以参考我的同事仝键的介绍文章“可视化架构设计——C4 介绍”。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 143,639评论 1 302
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 61,591评论 1 258
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 95,050评论 0 213
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 41,169评论 0 180
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 48,976评论 1 258
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 38,876评论 1 178
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 30,476评论 2 273
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 29,229评论 0 167
  • 想象着我的养父在大火中拼命挣扎,窒息,最后皮肤化为焦炭。我心中就已经是抑制不住地欢快,这就叫做以其人之道,还治其人...
    爱写小说的胖达阅读 29,095评论 6 234
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 32,579评论 0 213
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 29,356评论 2 215
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 30,698评论 1 232
  • 白月光回国,霸总把我这个替身辞退。还一脸阴沉的警告我。[不要出现在思思面前, 不然我有一百种方法让你生不如死。]我...
    爱写小说的胖达阅读 24,272评论 0 32
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 27,168评论 2 214
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 31,605评论 3 210
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 25,645评论 0 9
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,035评论 0 166
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 33,609评论 2 232
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 33,698评论 2 233

推荐阅读更多精彩内容