系统架构-架构评估

质量属性

性能

指系统的响应能力

指标:响应时间、吞吐量等。

设计策略:优先级队列、增加计算资源、减少计算开销、引入并发机制、采用资源调度

可靠性

在意外或错误使用的情况下维持软件系统的功能特性

指标:MTTF、MTBF、MTTR

设计策略:心跳、Ping/Echo、冗余、选举

可用性

系统能够正常运行的时间比例,经常用两次故障之间的时间长度或在出现故障时系统能够恢复正常的速度来表示。

指标:故障间隔时间

设计策略:心跳、Ping/Echo、冗余、选举

安全性

系统在向合法用户提供服务的同时能够阻止非授权用户使用的企图或拒绝服务的能力

指标:保密性、完整性、不可抵赖性、可控性

设计策略:加密、入侵检测、用户认证、用户授权、追踪审计

可修改行

能够快速的以较高的性能价格比对系统进行变更的能力

设计策略:接口-实现分类、抽象、信息隐蔽

功能性

系统所能完成所期望的工作的能力

可变性

体系结构经扩充或变更而称为新体系结构的能力,可扩展性。

互操作性

组成部分的软件不是独立存在的,经常与其他系统或自身环境间相互作用

质量属性场景

质量属性场景是一种面向特定质量属性的需求。

由六个部分组成:

  1. 刺激源:某个生成刺激的实体(人、计算机系统等)
  2. 刺激:当刺激到达系统时需要考虑的条件
  3. 环境:该刺激在某些条件内发生
  4. 制品:被刺激的对象,(用户界面、平台等)
  5. 响应:在刺激到达后采取的行动
  6. 响应度量:当响应发生时,应当能够以某种方式对其进行度量

软件架构评估

敏感点:为了实现某种特定的质量属性,一个或多个构件所具有的特性

权衡点:影响多个质量属性的特性

风险点与非风险点:可能引起风险的因素,可称为风险点;如果某件事是可接受的,则为非风险点

架构评估方式

基于调查问卷(检查表)的方式:要求评估人员对领域熟悉

基于度量的方式:制订一些定量指标来度量架构

基于场景的方式:首先确定应用领域的功能和软件架构的结构之间的映射,然后要设计用于体现待评估质量属性的场景,最后分析软件架构对场景的支持程度

基于场景的架构分析方法

SAAM:

SAAM是一种非功能质量属性的架构分析方法,是最早形成文档并得到广泛应用的软件架构分析方法。可修改性是SAAM分析的主要质量属性

ATAM:

架构权衡分析法ATAM,让架构师明确如何权衡多个质量目标。

ATAM被分为四个主要的活动领域:场景和需求收集、体系结构视图和场景实现、属性模型构造和分析、折中。强调以属性作为架构评估的核心概念

CBAM:

成本效益分析法,用来对架构建立的成本来进行设计和建模,让决策者根据骰子收益率来选择合适的架构

图片来源于网络

相关推荐
RestCloud1 小时前
一站式数据集成:iPaaS 如何让开发者和业务人员都满意?
前端·后端·架构
智慧源点2 小时前
阿里云高可用生产环境网络架构实战:VPC规划与多可用区部署
网络·阿里云·架构
安卓开发者2 小时前
鸿蒙Next ArkWeb进程解析:多进程架构如何提升Web体验
前端·架构·harmonyos
热心市民R先生2 小时前
IgH EtherCAT 主站核心技术解析:从架构到工业部署的底层逻辑
架构·igh
喂完待续5 小时前
【序列晋升】31 Spring Cloud App Broker 微服务时代的云服务代理框架
spring·spring cloud·微服务·云原生·架构·big data·序列晋升
武子康5 小时前
AI-调查研究-74-具身智能 机器人学习新突破:元学习与仿真到现实迁移的挑战与机遇
人工智能·程序人生·ai·职场和发展·系统架构·机器人·具身智能
lssjzmn6 小时前
构建实时消息应用:Spring Boot + Vue 与 WebSocket 的有机融合
java·后端·架构
Yeats_Liao7 小时前
物联网平台中的MongoDB(一)服务模块设计与架构实现
物联网·mongodb·架构
一水鉴天7 小时前
整体设计 之 绪 思维导图引擎 之 引 认知系统 之8 之 序 认知元架构 之4 统筹:范畴/分类/目录/条目 之2 (豆包助手 之6)
大数据·架构·认知科学
数据智能老司机9 小时前
自己动手写编程语言——源代码扫描
架构·编程语言·编译原理