系统架构设计(十八):ATAM

概述

**ATAM(Architecture Tradeoff Analysis Method)**是由美国卡内基梅隆大学 SEI(软件工程研究所)提出的一种用于评估软件架构方案的系统方法,核心目的是:

  • 评估架构是否满足质量属性需求(如性能、可用性、安全性等)
  • 识别架构决策中的权衡(Tradeoffs)
  • 揭示架构的风险、敏感点和权衡点

核心概念

术语 含义
质量属性 系统在非功能性方面的要求,如可用性、可扩展性、性能等
权衡点 某一设计决策会对多个质量属性产生冲突影响的位置
敏感点 架构中对系统质量属性产生重大影响的设计决策点
风险 架构中潜在的不确定因素,可能导致质量属性无法满足

分析流程(关键步骤)

ATAM 分为 四个阶段,九个步骤,如下所示:

阶段 1:前期准备

  1. 介绍评估过程(Present ATAM)
  2. 介绍业务驱动(Present Business Drivers)
  3. 介绍架构(Present Architecture)
  4. 确认质量属性目标(Identify Architectural Approaches and Quality Attribute Goals)

阶段 2:分析评估

  1. 分析架构方法 (Generate Quality Attribute Utility Tree)
    • 利用"实用树"(Utility Tree)列出系统质量属性的场景(如:系统在高并发下响应时间小于 1 秒)
  2. 分析架构方案的敏感点和权衡点
    • 通过分析发现架构中关键决策对多个属性的影响(例如缓存策略对性能和一致性的影响)

阶段 3:风险识别

  1. 分析风险、敏感点和权衡点
    • 如使用微服务提升可扩展性,但增加了部署和监控复杂度

阶段 4:总结与反馈

  1. 评估结果总结 (Present Results)
    • 总结风险清单、敏感点、权衡分析、质量属性满足情况等
  2. 编写评估报告(Follow-up)

输出成果

  1. 质量属性实用树
  2. 架构中的风险项列表
  3. 敏感点与权衡点说明
  4. 对架构改进的建议
  5. 是否满足业务目标的分析报告

典型应用场景

  • 在系统架构评审阶段使用
  • 比较不同架构方案
  • 为后续详细设计提供方向
  • 作为决策支持工具,权衡不同的质量属性需求
相关推荐
兵慌码乱7 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构
坏孩子的诺亚方舟14 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
桥田智能14 天前
桥田智能 QT-650S:面向白车身焊装的 800kg 重载快换解决方案
开发语言·qt·系统架构
@insist12314 天前
系统架构设计师-5G 技术、冗余设计与分层架构
5g·架构·系统架构·软考·系统架构设计师·软件水平考试
@insist12314 天前
系统架构设计师-网络存储 RAID 与 IPv6 协议全解析
网络·系统架构
山东点狮信息科技有限公司15 天前
企业级 MES 制造执行系统架构设计与实践
spring cloud·性能优化·系统架构·策略模式·点狮
@insist12315 天前
系统架构设计师-计算机网络基础体系全梳理
计算机网络·系统架构·软考·系统架构设计师·软件水平考试
山东点狮信息科技有限公司15 天前
点狮OA-企业级 OA 办公自动化系统架构设计与实践
spring cloud·微服务·性能优化·架构·系统架构
taocarts_bidfans15 天前
反向海淘系统架构设计与 taocarts 分层实践
系统架构·反向海淘·taocarts
生成论实验室15 天前
六十四卦态势操作系统技术白皮书
人工智能·语言模型·系统架构·机器人·自动驾驶·agi·安全架构