当前位置: 首页 > news >正文

系统架构设计(十八):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. 是否满足业务目标的分析报告

典型应用场景

  • 在系统架构评审阶段使用
  • 比较不同架构方案
  • 为后续详细设计提供方向
  • 作为决策支持工具,权衡不同的质量属性需求
http://www.xdnf.cn/news/584245.html

相关文章:

  • 《棒球百科》棒球运动规则·棒球1号位
  • 【竖排繁体识别】如何将竖排繁体图片文字识别转横排繁体,转横排简体导出文本文档,基于WPF和腾讯OCR的实现方案
  • 免费轻量便携截图 录屏 OCR 翻译四合一!提升办公效率
  • 解决weman框架redis报错:Class “llluminatelRedis\RedisManager“ not found
  • 【Java高阶面经:数据库篇】18、分布式事务:如何在分库分表中实现高性能与一致性?
  • 零基础设计模式——第二部分:创建型模式 - 原型模式
  • HCIP(广域网)
  • Normalized Blind Deconvolution论文阅读
  • UART串口两种连接方式
  • 笔记本6GB本地可跑的图生视频项目(FramePack)
  • EtpBot:安卓自动化脚本开发神器
  • 了解Android studio 初学者零基础推荐(2)
  • 正则表达式篇
  • element ui 表格实现单选
  • v2.0 技术篇目录-研究生如何选择编程技术
  • iOS工厂模式
  • uniapp-商城-65-shop(1-品牌信息显示,将数据库信息同步到vuex的state)
  • 如何构建一个简单的AI Agent(极简指南)
  • 深度学习入门到实战:用PyTorch打通数学、张量与模型训练全链路​
  • 使用 A2A Python SDK 实现 CurrencyAgent
  • 开闭原则 (Open/Closed Principle, OCP)
  • leetcode hot100刷题日记——10.螺旋矩阵
  • day33 python深度学习入门
  • jmeter登录接口生成一批token并写入csv文件
  • 浪潮Inspur服务器产品线概述
  • 【paddle】常见的数学运算
  • Ubuntu 22.04上升级npm版本
  • 升级node@22后运行npm install报错 distutils not found
  • canvas(三)-动画3d
  • iisARR负均衡