什么是软件架构?#
软件架构就是系统设计,以及它对诸如性能、安全和可修改性等系统所产生的影响。
软件架构抉择很重要,架构是系统骨骼,直接影响质量属性,并约束整个系统。
从某个角度来说,架构与功能可以互相组合,只是不同组合有不同表现效果而已。
利用模型和抽象概念去构建和解释系统架构。
软件设计可分为软件架构和详细设计。
软件架构的定义,来自卡内基.梅隆大学软件工程研究所(MEI)定义:
计算系统的软件架构是解释给系统锁所需的结构体集合,其中包括:软件元素、元素之间的相互关系,以及二者各自的属性。
该定义的重点:元素、元素之间的关系以及元素的属性。
架构是设计的宏观部分。
架构是必须在项目早期做出的一组设计决策。
软件架构为什么重要#
软件架构重要性在于它会影响整个软件的系统。只有审慎的选择架构,才能降低风险,避免失败。
架构扮演者系统骨架的角色
架构影响质量属性
架构与功能(基本上)正交的
架构还是对系统的约束
系统架构不仅要支持所需的功能,同时还能促进或者抑制诸如安全或性能等系统质量。
作者举例:
人和马的身体骨架都能够运输苹果到市场的功能,但是运输效率和数量上相差甚远。
选择一种架构使得系统能够工作并不是难事,但满足质量属性方面,有的选择是事半功倍,有的选择则会事倍功半。
架构何时变得重要#
解空间小:问题复杂,很难设计出好的解决方案,那么架构就显得尤为重要。
翻译成 解,真不好理解
高的失败风险:任何时候,失败的风险越高,就越需要保证正确架构
难以实现的质量属性:架构会影响质量属性的能力。开发一个邮件系统并不难,然而,一般要求高性能支持百万级用户,就变得异常困难
我理解的质量属性:就是架构的目标,比如高可用,安全性,可伸缩等等。翻译成质量属性也比较难理解。
全新领域:面对全新领域,或者对于设计者而言是全新领域,就需要对架构给予更多关注。
产品线:一些产品线会共享某一通用架构。
企业架构师:企业架构师是负责多个应用系统的开发者。他们并不会控制任何一个应用系