软件系统架构思维方式
创始人
2024-06-03 08:17:13
0

这节我们来说说在构建软件架构的过程中,我们需要的几种思维方式。我们生活和学习中常常有思维方式的转换,构建软件架构时也同样需要不同的思维方式。

对于构建一个软件架构来说,从思维方式上入手有很多值得我们学习的地方,这涉及到如何抽象构建架构的思维方式。这篇我们就来讲讲,软件系统架构思维方式有哪些。

架构既承载了我们对这个项目的抽象思维构建,也同时帮助了我们理清业务体系的方向。如果要说软件研发、系统架构中最重要的能力是什么,我会毫不犹豫回答是抽象能力。

在系统架构和设计中,抽象能力是个比较重要的能力,其实抽象能力在生活也很重要,只是在软件设计架构中尤其的重要。一个项目在最初的设计时是没有可见目标的,也就是说我们需要凭空创造出一个我们能看到或想象的到的构建目标,这个目标大概率指向软件形成的最终形态不会偏离很多。抽象能力在这个特殊时期发挥了重要作用,它可以帮助我们在没有形成任何可见可幻想的实际目标之前,描绘出一个大致的轮廓,以至于我们在实现架构途中能有个可见的标准和目标。因此实际工作中抽象能力的强弱,直接决定我们所能解决问题的复杂度和规模大小。

软件系统架构设计和小朋友搭积木无本质差异,只是解决的问题域和规模不同罢了。架构师先要在大脑中形成抽象概念,然后是子模块分解,以及子模块之间的沟通方式,然后是依次实现子模块,最后将子模块拼装组合起来,形成最后系统。我们常说编程和架构设计就是搭积木,优秀的架构师受职业习惯影响,眼睛里看到的世界都是模块化拼装组合式的。

抽象能力不仅对软件系统架构设计重要,对建筑、商业、管理等人类其它领域活动也同样非常重要。可以这样认为,我们生存的世界都是在抽象的基础上构建起来的,离开抽象人类将对事物的构建寸步难行。

我在一篇名为《优秀架构师必须掌握的架构思维》的文章中看到关于抽象能力分析很好的分析,以下部分内容引申了他的文章。

第一种,分层思维

分层是我们应对和管理复杂性的基本思维武器.

面对一个复杂的系统,我们一开始总是无从下手,就好比一下子在我们面前摆了有很多很多的问题,杂乱无章。这很大程度都会导致我们慌张,焦急,惶恐等心理波动。分层思维,就能很好的帮助我们抽象一个复杂的系统的架构层次,从而清晰的描述了我们有多少层面的事务需要我们解决,以及解决层级的先后次序。

构建一套复杂系统,我们把整个系统划分成若干个层次,每一层专注解决某个领域的问题,并向上提供服务。这样的抽象做法,让复杂的事务变得更加清晰有序。有些层次并不一定是横向的,也可以是纵向的,纵向的层次贯穿其他横向层次,称为共享层。如下图:

下面我们来介绍几个用分层思维作为抽象方法的架构案例:

一个中小型的Spring Web应用程序,我们一般会设计成三层架构:

Linux操作系统是经典的分层架构,如下图:

TCP/IP协议栈也是经典的分层架构,如下图:

如果你关注人类文明演化史,你会发现今天的人类世界也是以分层方式一层层搭建和演化出来的。今天的互联网系统可以认为是现代文明的一个层次,其上是基于互联网的现代商业,其下是现代电子工业基础设施,诸如此类。

第二种,分治思维

分而治之也是应对和管理复杂性的一般性方法,下图展示一个分治的思维流程:

这是我2015年在思考Unity3D手游项目开发整体流程时,用分治法抽象出来的对整个问题的分解。我首先把code编码作为主中心,再把除了code的以外的事拆分成打包发布,资源部署到外网与检测,版本控制,项目管理平台。再对拆分出来的大块问题,进行细化,分解到具体的某个小问题。

对于一个无法一次解决的大问题,我们会先把大问题分解成若干个子问题,如果子问题还无法直接解决,则继续分解成子子问题,直到可以直接解决的程度,这个是分解(divide)的过程;然后将子子问题的解组合拼装成子问题的解,再将子问题的解组合拼装成原问题的解,这个是组合(combine)的过程。

在生活中分治思维,解决大问题,复杂问题,是很好手段。特别是当遇到那些你从未处理过的问题时,或者特别复杂超出你能力范围的问题时,把它分解、拆分、解刨、撕裂。把大问题先分成几大块的问题,再从这几大块问题入手,对每个大块问题再分解,拆分成小块问题。倘若小块问题仍然无法进行,或者还是没有思路,再拆分,再解刨,再分解,直到分解到你能开始着手解决了为止。这样一步步,一点点,把小的问题解决了,就是把大块问题解决了。随着时间的推移,不断解决细分的小问题,大块问题被迎刃而解,最后大块问题解决完后,更大块问题迎刃而解。

第三种,演化思维

经常有人在讨论:架构是设计出来的?还是演化出来的?我个人基于多年的经验认为,架构既是设计出来的,同时也是演化出来的,对于互联网系统,基本上可以说是三分设计,七分演化,而且是在设计中演化,在演化中设计,一个不断迭代的过程。

在互联网软件系统的整个生命周期过程中,前期的设计和开发大致只占三分,在后面的七分时间里,架构师需要根据用户的反馈对架构进行不断的调整。我认为架构师除了要利用自身的架构设计能力,同时也要学会借助用户反馈和进化的力量,推动架构的持续演进,这个就是演化式架构思维。

当然一开始的架构设计非常重要,架构定系统基本就成型了,不容马虎。同时,优秀的架构师深知,能够不断应对环境变化的系统,才是有生命力的系统,架构的好坏,很大部分取决于它应对变化的灵活性。所以具有演化式思维的架构师,能够在一开始设计时就考虑到后续架构的演化特性,并且将灵活应对变化的能力作为架构设计的主要考量。

从单块架构开始,随着架构师对业务域理解的不断深入,也随着业务和团队规模的不断扩大,渐进式地把单块架构拆分成微服务架构的思路,这就是演化式架构的思维。如果你观察现实世界中一些互联网公司(例如eBay,阿里,Netflix等等)的系统架构,大部分走得都是演化式架构的路线。

下图是建筑的演化史,在每个阶段,你可以看到设计的影子,但如果时间线拉得足够长,演化的特性就出来了。

总结下,我们上文中我们强调了抽象思维在架构设计中的重要性,以及抽象思维的几种用法,包括分层思维,分治思维,以及演化思维,他们帮助我们在抽象的架构设计中起到了很好的作用。

相关内容

热门资讯

小仓鼠在笼子里一动不动的是怎么... 小仓鼠在笼子里一动不动的是怎么回事?小仓鼠应该是生病了,建议尽快处理,找兽医看看,他们最专业。目前应...
扬州何园的寻访感受 扬州何园的寻访感受 你好,请参考: 初见何园,似乎有种似曾相识的感觉,或许意识到这种想...
童年傻事作文---速来 童年傻事作文---速来童年傻事 童年是多么美好,童年的生活令人向往,童年的天空总是那么蓝,而童...
家庭幽默大赛老韩头一家幽默服装... 家庭幽默大赛老韩头一家幽默服装秀家庭幽默大赛老韩头一家幽默服装秀这都被他看出来了  今天晒内裤了,室...
乐器名称 乐器名称我在小提琴协奏曲《梁祝》的视频里这种乐器不知叫什么名字,请懂音乐和乐器的朋友给予解答,谢谢。...
电视剧《老马家的幸福往事》中的... 电视剧《老马家的幸福往事》中的马鸣和徐丽娜在马鸣的大学里的图书馆里偷书时用留声机听的歌是什么名字的请...
流鬼的介绍 流鬼的介绍 流鬼,是古代民族,分布在今俄罗斯勘察加半岛,有数万人。
请问为爱所困火吗 请问为爱所困火吗一般般。爱情偶像剧。此剧上一年开播,还上了微博热搜榜我认为很火,为爱所困第二部还有不...
什么是手诊 什么是手诊手诊的概念就是指通过人体手的纹路形态、变化、规律等方式,对人体器官的演变作出推理的一种防治...
双子星公主法和希的有几集,第一... 双子星公主法和希的有几集,第一部第二部都要,如果知道第三部也透露一点,请求不要编,法和希最后怎样了拜...
王熙凤简介 王熙凤简介《红楼梦》中人物,贾琏之妻,王夫人的内侄女。长着一双丹凤三角眼,两弯柳叶吊梢眉,身量苗条,...
大学生应从哪些方面进行自我探索 大学生应从哪些方面进行自我探索兴趣、能力、价值观、性格,这四个是最主要的方面,其中价值观是核心
谁有好看的卡通人物的电脑背景! 谁有好看的卡通人物的电脑背景!卡通人物的背景要清色! 看得清 要男生的 我有Clannad主题...
幼儿园小班孩子座位固定好还是经... 幼儿园小班孩子座位固定好还是经常换好?我家孩子座位老换,我觉得不好,大家觉得呢?... 我家孩子座...
我的爸爸的作文 我的爸爸的作文我的父亲 人们常说父爱如山,可在我看来,我的父亲对我的爱,并非完全如山那样严峻,有时却...
潘朵拉之心第二季动漫什么时候出 潘朵拉之心第二季动漫什么时候出动画只出了第一季 没有要出第二季的消息 可能性估计很小目前漫画还在连载...
时不我待是什么意思 时不我待是什么意思时不我待的意思是时间不等待人,要抓紧时间,不要虚度光阴。出处:日月逝矣,岁不我与。...
葫芦小金刚里大娃怎么被抓的 葫芦小金刚里大娃怎么被抓的掉泥潭被捉的
有一部小说叫穿越千年来爱你还是... 有一部小说叫穿越千年来爱你还是什么的有一部小说叫穿越千年来爱你还是什么的内容讲的是一个女的在路上走着...
火影忍者力 米娜是红眼吗 火影忍者力 米娜是红眼吗红眼?首先这几集是原创,非岸本创作。在岸本的剧情结构里面只有木叶白眼、写轮眼...