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

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

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

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

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

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

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

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

第一种,分层思维

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

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

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

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

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

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

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

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

第二种,分治思维

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

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

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

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

第三种,演化思维

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

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

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

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

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

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

相关内容

热门资讯

122.(leaflet篇)l... 听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
Vue使用pdf-lib为文件... 之前也写过两篇预览pdf的,但是没有加水印,这是链接:Vu...
PyQt5数据库开发1 4.1... 文章目录 前言 步骤/方法 1 使用windows身份登录 2 启用混合登录模式 3 允许远程连接服...
Android studio ... 解决 Android studio 出现“The emulator process for AVD ...
Linux基础命令大全(上) ♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维...
再谈解决“因为文件包含病毒或潜... 前面出了一篇博文专门来解决“因为文件包含病毒或潜在的垃圾软件”的问题,其中第二种方法有...
南京邮电大学通达学院2023c... 题目展示 一.问题描述 实验题目1 定义一个学生类,其中包括如下内容: (1)私有数据成员 ①年龄 ...
PageObject 六大原则 PageObject六大原则: 1.封装服务的方法 2.不要暴露页面的细节 3.通过r...
【Linux网络编程】01:S... Socket多进程 OVERVIEWSocket多进程1.Server2.Client3.bug&...
数据结构刷题(二十五):122... 1.122. 买卖股票的最佳时机 II思路:贪心。把利润分解为每天为单位的维度,然后收...
浏览器事件循环 事件循环 浏览器的进程模型 何为进程? 程序运行需要有它自己专属的内存空间࿰...
8个免费图片/照片压缩工具帮您... 继续查看一些最好的图像压缩工具,以提升用户体验和存储空间以及网站使用支持。 无数图像压...
计算机二级Python备考(2... 目录  一、选择题 1.在Python语言中: 2.知识点 二、基本操作题 1. j...
端电压 相电压 线电压 记得刚接触矢量控制的时候,拿到板子,就赶紧去测各种波形,结...
如何使用Python检测和识别... 车牌检测与识别技术用途广泛,可以用于道路系统、无票停车场、车辆门禁等。这项技术结合了计...
带环链表详解 目录 一、什么是环形链表 二、判断是否为环形链表 2.1 具体题目 2.2 具体思路 2.3 思路的...
【C语言进阶:刨根究底字符串函... 本节重点内容: 深入理解strcpy函数的使用学会strcpy函数的模拟实现⚡strc...
Django web开发(一)... 文章目录前端开发1.快速开发网站2.标签2.1 编码2.2 title2.3 标题2.4 div和s...