探寻软件架构的本质,到底什么是架构
Tech导读
本文将深入探讨软件架构的核心概念,解析“架构”这一术语的本质含义。将从软件架构的定义出发,阐述其在软件开发过程中的重要性,以及如何通过架构来实现技术和业务目标的对齐。通过对架构的深刻理解,本文旨在帮助开发者和架构师更好地把握软件设计的高层次视角,并作出明智的架构决策。
导读
本文将深入探讨软件架构的核心概念,解析“架构”这一术语的本质含义。将从软件架构的定义出发,阐述其在软件开发过程中的重要性,以及如何通过架构来实现技术和业务目标的对齐。通过对架构的深刻理解,本文旨在帮助开发者和架构师更好地把握软件设计的高层次视角,并作出明智的架构决策。
01 到底什么是软件架构?
在今年的敏捷团队建设中,我通过Suite执行器实现了一键自动化单元测试。Juint除了Suite执行器还有哪些执行器呢?由此我的Runner探索之旅开始了!
定义“架构是什么” 是件非常困难的事情,不同的组织对于软件架构有不同的定义,每个人心中也有自身对于系统架构定义的认知。就好比无法百分之百表述模型而只能产出模型不同维度的视图一样,对架构进行完备的定义是不可能的。
the fundamental organization of a system, embodied in its components, their relationships to each other and the environment, and the principles governing its design and evolution --ANSI/IEEE
将系统架构定义为:架构是系统组织结构 + 组件及联系(组件间以及组件和环境之间) + 原则的组合。通过图形化的形式表述该架构定义如下图所示,这是一个非常简洁、概念清晰的定义,其言简意赅的表达了架构的几个核心要素:系统的组织:表达系统的宏观结构 组件及联系:组件化的思维,同时突出了环境要素。组件表达了系统的模块化,组件相互之间及组件与环境之间的关联表达元素间的相互作用。
原则:用于指导设计和系统演进的原则
大师 Martin Fowler对于架构的定义有着更加简洁的抽象,Martin Fowler 认为软件架构是:重要并且难以改变的决策。架构设计是关于权衡的艺术,架构设计过程中充满了各种各样的决策,这些决策也终将反应系统架构。
Software Architecture = Important and hard to change decisions --Martin Fowler而Ralph Johnson则对架构有更加 “泛化” 的定义:软件架构就是重要的东西,不论它是什么!
以上的定义从高层抽象视角对什么是架构给予了自己的回答,相比之下,Neil Ford 从架构组成元素入手,从更偏向实践的角度对架构进行了阐述。核心思想是软件系统的架构包括以下组合元素:
结构:应用系统所选择的架构风格,比如微服务架构、单体架构还是SOA等 架构属性:系统的非功能性属性,比如性能、可用性、可维护性等 架构决策:系统设计过程中重要的架构决策 设计原则:设计过程中的指导性原则 结构
结构是系统架构的重要组成部分,其从宏观上表述了系统的结构组成。架构设计的核心任务之一是为系统选择合适的架构风格。比如,架构师基于上下文的权衡,可以选择模块化单体架构风格,也可以选择微服务架构风格。
架构属性
架构属性亦称质量属性,或非功能属性,通常表示系统需要具备或满足的某种 “能力”,比如高性能、可扩展性、弹性、伸缩性、容错性、可测试性、可维护性等等。架构设计的目标需要关注系统需要满足的架构属性,架构最终要体现对架构属性支持的相关架构决策。架构属性众多,系统需要关注的是这些架构属性的子集,具体的某次特定的架构设计所需要关注的架构属性需要依据问题域的上下文而具体分析。同时,不同的架构属性间可能存在冲突,这种情况同样需要架构师的权衡和决策。
架构决策
架构决策是系统架构设计过程中对解决方案的选择,其描述了系统必须遵循的规则。架构决策随着权衡分析而自然存在,其是系统架构设计的重要维度之一。并不是所有的决策都是架构决策,架构决策应该关注对系统有重要影响的部分。比如对架构风格的选择对系统存在重要影响,其改变的成本较高,理当属于架构决策的范畴。比较典型架构决策包括但不限于:
直接影响高优先级的架构属性
修改对外接口:对外提供的接口修改往往需要进行充分影响分析
引入或者移除依赖:依赖的加入和移除往往标示着组件能力的引进和废弃
改变系统的通用结构:工程结构是应用架构的重要维度之一
迫使研发人员改变开发方式
接受战略性技术债:重构影响较大的技术债往往对现有系统会有较大影响
设计原则
设计原则与架构决策不同,其本质区别是:设计原则是一种指导,而非强制的规则。架构决策需要遵守,设计原则提供参考性指引。
比如,设计原则可能是:在可能的情况下,跨系统间的通信尽可能使用异步消息机制以提高性能和降低耦合。
以上对架构的定义各有特点:
IEEE定义更加结构化和规范化 Martin Fowler的定义侧重架构决策的重要性 Ralph Johnson 则更加泛化,突出 “重要” 这一核心因子 Neil Ford则更具象化
02
架构设计的边界
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
系统的架构应该设计到什么粒度?
"架构设计" 太过详细,涵盖了实现的 “细枝末节”,自己除了CRUD没有发挥的空间
"架构设计" 太过宏观,基于设计方案根本无法指导开发,自己还得重新设计
很多架构师自身对架构和设计的边界缺乏深入认知,相比于对架构边界的缩小,更多时候会出现架构设计边界放大的情况:
架构师把架构设计当作详细的技术方案设计,牢牢把控系统实现的所有细节,产出大量的设计文档,然后交由核心开发人员做代码实现的执行工作。
这种现象会导致如下问题:
压缩了团队核心开发人员的设计发挥空间,不利于其技术水平及认知的提升 作为架构师你真的能将所有的细节都Cover住吗?即使耗费巨大精力完成了 “完备” 的设计,来自一线开发所面临的各种场景是否能够提前预知和捕获? 如果需求迭代持续如此,作为核心开发人员多半会有“怨言” 作为团队的架构师精力有限,持续的细节输出会耗费巨大精力,而无法关注更加宏观的层面
以上问题的根源是什么?不能明确架构设计的边界!
架构设计与设计(实现相关)的边界或粒度问题 团队架构师与开发人员间的职责边界
判断架构边界的前提之一是:明确架构和设计的关系!
所有的架构都是设计,但设计不一定是架构!
从架构的定义看架构设计的边界,选取两个视角:
架构是系统中重要的东西!无论它是什么(之所以重要,是因为改变的成本高) 架构设计涵盖系统中重要的架构决策
所以,架构设计应该涵盖系统中重要的东西,这些 “重要的东西” 可能是:
应用架构风格的选择 子系统间信息通信的方式 工程采取的分层以及层间约束 工程应该遵循的开发规范 工程引入的三方类库,或者三方框架 高优先级的架构属性:比如某次需求建设非常关注系统的性能,或者扩展性等架构属性 其它 "重要的东西"
架构设计涵盖了系统所需的重要的架构决策,从宏观层面对系统实现予以指引。而详细的设计则为具体的开发实现提供指导,比如,详细的E-R图设计、具体的代码级别的模式选择、某个组件的具体实现等等。
架构不是一成不变,需要持续演进,而实现相关的设计也可能在项目进行中持续变化,因此,二者不能完全割裂,而是需要在实现过程中进行双向反馈:
架构设计信息要高效的同步至开发人员 实现过程中的变更同样也要回向反馈至架构,以便对架构设计进行调整
在进行架构边界判定时要注意一个至关重要的因子:上下文!!!以上的判断准则必须要给定的上下文中才有价值。
如果上下文非常关注系统的扩展性,该架构属性是高优先级的架构属性,那么,核心模块的策略模式的应用可以看作是架构设计的范畴。而如果上下文中扩展性不是关注的高优先级的架构属性,相比之下更关注性能,那么,这种代码级的设计模式选择应该属于架构设计的范畴之外了,而需要划分到实现设计层面,交由核心开发自主决定。
03 架构模式(Patterns)与架构风格(Styles)?
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目标页面展示到屏幕。
架构模式和架构风格是极容易混淆的两个概念,很多开发人员将其理解为同一事物,而实际上二者有本质区别。
架构风格是系统设计的顶层抽象,从宏观视角表述系统组成。更进一步,架构风格聚焦于系统的分层、模块以及交互形式。
架构模式聚焦于对重复出现问题提供解决方案
架构模式可以应用于架构风格,在同一架构风格上下文内可以应用一或多种架构模式
架构风格可以组合以产生新的架构风格
比较典型的例子是CQRS:CQRS本身是一种模式,将命令和查询的职责在不同维度进行分离。该模式可以在单体架构风格中使用,也可以在微服务架构风格中使用,当然也可以在SOA架构风格中使用。
04 为什么要做架构设计?
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目
做,收益高
不做,成本高
05 开发人员和架构师的知识模型
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目
作为架构师,之所以技术的广度比深度更重要,是因为架构师的重要职责之一是进行架构决策。系统架构设计是关于权衡的艺术,在特定的问题域上下文下,架构师需要在诸多可行的解决方案间进行权衡和决策,这也对其技术广度提出了要求。开发人员成长为架构师,应该更加关注知识的广度,并在几个特定领域深耕,以便有足够的知识支撑架构决策。
识记:识别和回溯事实性知识 理解:理解事实的内涵 应用:将事实、规则、概念、思想加以应用 分析:将信息分解、关联、区分、实验、测试 评估:将信息或思想的价值进行评价 创造:整合不同的信息形成新的知识体系
悟:由内向外,通过不断积累、持续思考,由量变到质变,直至 “开悟”
破:自外向内,高层次或不同的思想输入碰撞,加速认知层次的突破
为学日益,为道日损。损之又损,以至于无为。无为而无不为。——《道德经》
06 结语
理解,首先 MCube 会依据模板缓存状态判断是否需要网络获取最新模板,当获取到模板后进行模板加载,加载阶段会将产物转换为视图树的结构,转换完成后将通过表达式引擎解析表达式并取得正确的值,通过事件解析引擎解析用户自定义事件并完成事件的绑定,完成解析赋值以及事件绑定后进行视图的渲染,最终将目
求分享
求点赞
求在看