软件架构之-论软件系统架构评估以及应用
论软件系统架构评估以及应用
- 摘要
- 正文
摘要
2023年2月,本人所在集团公司承接了长三角地区某省渔船图纸电子化审查系统项目开发,该项目旨在为长三角地区渔船建造设计院,以及渔船图纸审查机构提供一个便捷化的服务平台。在此项目中,我作为项目组成员参与项目的建设工作,并担任系统架构师一职,全权负责该项目的需求分析和架构设计等工作。该项目以实现渔船电子化审图为统一目标,为长三角地区渔船建造设计院、渔船审图机构、以及第三方技术审图公司提供一体化服务,推进长三角地区渔船建造行业发展。我们经过实践认为架构评估是软件项目开发中重要环节,本文以该项目为例,主要讨论了项目架构评估方法,包括:架构权衡分析法(ATAM)以及软件架构分析法(SAAM)等,选择正确的系统架构评估方法,对于保证架构设计的合理性,完整性,和针对性,保证系统质量,降低成本以及投资风险,都是很有必要的。渔船图纸审查项目的系统架构经过严格、规范化的评估并付诸实施,历时10个月,项目最终上线,赢得了客户的良好评价。
正文
近年来,随着国家对渔船建造行业的大力支持,以及渔船建造技术的快速发展,渔船建造的规模越来越大,针对渔船建造图纸数量也迅速增加,传统的纸质化审图已经越来不能满足渔船建造设计院的需求,对于存在问题图纸的修改审核、设计师往往奔走与设计院与审图机构之间,耗费大量人力、物力。2023年初长三角地区某省为了推进渔船建造业的一体化发展,实现渔船审图“零跑腿”的业务需求,发起了渔船图纸电子化审查项目,该项目投资1000万元,计划10个月完成,并对项目了公开招标,我公司成功中标。
2023年2月,接到系统开发研发任务后,我所在部门领导高度重视,第一时间成立了专门的开发小组,抽调并组织骨干力量进行系统开发。本人有幸在该项目中担任系统架构师角色,全面主持了该项目的架构设计以及开发工作,并在项目中实践了系统架构评估方法以及应用,得到了项目组成员认可。下面重点阐述我在本项目中的实践。
目前最主要的架构评估方法分为两种,分别详述如下:
1、 架构权衡分析法(ATAM)
ATAM主要针对性能、可用性、安全性、可修改性等质量属性进行评价和折中,其目标是在考虑多个相互影响的质量属性的情况下,从原则上提供一种理解软件体系结构的能力方法。ATAM的主要活动包括:需求收集、架构视图描述、属性模型构造和分析、架构决策与折中等。
2、 基于场景的架构分析法(SAAM)
SAAM把任务形式的质量属性都具体化为场景,使用场景技术为评估技术,以场景代表描述体系结构属性的基础,描述了各种系统必须支持的活动和将要发生的变化。SAAM的目标是描述应用程序属性的文档,验证基本的体系结构假设和原则。SAAM评价活动包括:场景开发、架构描述、单个场景评估、多个场景交互评估、总体评估。
选择正确的体系架构评估方法,能够保证架构设计的合理性、完整性和针对性,保证系统质量、降低成本以及投资风险。所以渔船图纸审核项目组在对架构评估方法选择时,结合平台自身的重要性以及涉及较多重点审图机构特点,仔细考察,反复对比了两种主要方法,最终采用了ATAM为架构评估方法。
渔船图纸审查系统平台本身是一个涉及面比较广泛、影响比较大的项目,它向前对接某省内所有渔船设计院机构,向后对接某省所有渔船图纸审核机构,全省所有渔船图纸数据审核都需经过此平台。所以渔船图纸审核平台建设对于非功能质量属性要求非常高,需要分析很多重要且关键的质量属性,例如:性能、可用性、安全性、可修改性等,并在各质量属性中做好权衡、折中。而ATAM在评估技术、关注质量属性、特定目标、方法活动、产出质量属性效应树等各方面都完美匹配渔船图纸审查平台的需求。在架构设计完成之后,渔船图纸审查项目组设计了架构评估工作流程。参加架构平台的人员来自比较重要的渔船设计院的首席架构师、负责人、以及审图机构的相关专家、技术负责人以及相关领导等。重要干系人一起参与整个额架构评估工作,整个工作分4个阶段进行。
一、 描述和介绍阶段
作为渔船图纸审查项目的架构师,我首先项大家介绍了ATAM架构评估方法的流程以及细则,确保大家理解ATAM方法的运作过程。然后有项目产品负责人着重阐述了项目建设的业务动机,包括项目的关键性业务需求、技术指标、功能范围、以及渔船设计院、以及审图机构的相关诉求等,确保大家明确渔船图纸审查平台建设目的。最后有我来描述平台总体架构设计、各业务模块划分以及交互、关键技术选型等。
二、 调查和分析阶段
由各单位代表提出场景述求,并加以记录和归类整理,生成质量属性效应树。比如,渔船设计院负责人提出,在大量图纸上传、以及图纸预览的情况下,平台需有能力处理100万次并发请求的能力,归类为性能属性。渔船审图机构专家提出“由于审图中包含图纸的敏感信息,所以网络请求需要提升加密力度,比如采用RSA算法”归类为安全属性;同时渔船审图机构技术负责人提出“渔船图纸审查平台作为省级应用平台,必须有技术手段保证机房发生问题时,秒级切换到备用机房”归类为可用性;我们项目组人员也指出“在后期迭代过程中,系统要容易扩展新功能”归类为客修改属性。
经过调查所有相关方的诉求后,我们收集了上百个场景,并根据重要性对这些场景设置了权重,通过归纳整理,我们分析后发现,大多数场景权重都集中在:性能、可用性、安全性、可修改性四个属性。然后,我们组织项目主技术负责人、技术骨干、架构小组进行分析,进一步识别其中的权衡点、敏感点和风险点。比如“采用RSA加密算法虽然能提升安全性,但计算量比较大,影响请求响应时间”属于权衡点;“对可用性达到99.999%的要求可能会因为采用主动沉余技术,而造成投入的软硬件成本几句增加”属于敏感点;“如果机房建设未能如期完成,可能导致系统架构部分实现,而影响整体功能”属于风险点。
三、 测试阶段
由于我们在前一阶段确定了场景的权重,并因此归纳了渔船图纸审查平台对于质量属性的优先级,级性能和可用性最高,而安全性和可修改性较低。我们依据属性优先级来检验我们最终的架构方案,并充分评估实现方案的可行性和合理性。性能方面,我们设置了三个中心机房,在每个机房部署了100套微服务实例,并做好负载均衡策略,并模拟100万条并发数据进行请求。可用性方面,六个机房互为主备,避免机房不可用;机房内采用双网关以及负载均衡硬件,提升接入层的可用性;应用层采用负载均衡分布式集群微服务架构,提升服务器整体可用性;数据层采用Mysql主从模式的主动沉余,以及分库,分表技术进一步降低出现问题的影响范围。在权衡点决策时,我们依据先保证系统性能的原则。比如我们采用计算量不大的对称加密算法,保证系统性能不受影响,但通过定时自动更新对称密钥机制来降低对称密钥被破解的风险,从而在性能和安全性之间达到最佳选择。
经过架构评估,我们将评估过程和结果汇总整理成文档。文档包括:架构分析方法文档、不同场景以及优先级,质量属性效应树,权衡点决策、风险点评估、会议记录等。
综上所述,由于运用了ATAM的评估方法和活动流程,我们做成了合理的架构决策,保证了项目架构设计的正确性,验证了各项质量需求,保证了系统实现、测试、验收工作的顺利实施,历时10个月,项目顺利上线,并且得到了业内外行业认可,我们还持续优化并身故扩展机房规模,在百万级的并发访问的情况下,系统性能经受了性能考验。这也充分说明了,以ATAM为代表的架构评估方法是验证架构设计的重要手段。
相关文章:
软件架构之-论软件系统架构评估以及应用
论软件系统架构评估以及应用 摘要正文 摘要 2023年2月,本人所在集团公司承接了长三角地区某省渔船图纸电子化审查系统项目开发,该项目旨在为长三角地区渔船建造设计院,以及渔船图纸审查机构提供一个便捷化的服务平台。在此项目中,…...

低延迟与高性能的技术优势解析:SmartPlayer VS VLC Media Player
在实时视频流的应用中,RTSP(Real-Time Streaming Protocol)播放器扮演着至关重要的角色,尤其是在视频监控、远程医疗、直播等高实时性需求的场景中。随着行业需求的不断升级,对播放器的低延迟、稳定性、兼容性等方面的…...
pytorch小记(十九):深入理解 PyTorch 的 `torch.randint()` 与 `.long()` 转换
pytorch小记(十九):深入理解 PyTorch 的 torch.randint 与 .long 转换 一、torch.randint() 基本概念示例:生成一个二维随机整型张量 二、为什么需要调用 .long()三、典型场景示例1. 随机索引采样2. 伪标签生成3. 直接在 GPU 上生…...
深入解析Spring Boot与微服务架构:从入门到实践
深入解析Spring Boot与微服务架构:从入门到实践 引言 Spring Boot作为Java生态中最受欢迎的框架之一,以其简洁的配置和强大的功能赢得了开发者的青睐。本文将带领大家从Spring Boot的基础知识入手,逐步深入到微服务架构的实践,帮…...

【交互 / 差分约束】
题目 代码 #include <bits/stdc.h> using namespace std; using ll long long;const int N 10510; const int M 200 * 500 10; int h[N], ne[M], e[M], w[M], idx; ll d[N]; int n, m; bool st[N]; int cnt[N];void add(int a, int b, int c) {w[idx] c, e[idx] b…...

宝塔面板部署前后端项目SpringBoot+Vue2
这篇博客主要用来记录宝塔部署前端后端项目的过程。因为宝塔部署有点麻烦,至少在我看来挺麻烦的。我还是喜欢原始的ssh连接服务器进行操作。但是公司有项目用到了宝塔,没办法啊,只能摸索记录一下。 我们需要提前准备好后端项目的jar包和前端项…...

现代生活健康养生新视角
在科技飞速发展的今天,我们的生活方式发生巨大转变,健康养生也需要新视角。从光线、声音等生活细节入手,能为健康管理开辟新路径。 光线与健康密切相关。早晨接触自然光线,可调节生物钟,提升血清素水平,…...
鸿蒙Next API17新特性学习之如何使用新增鼠标轴事件
今天咱们接着学习鸿蒙开发文档API17版本的新特性——对鼠标轴事件的支持。这对于需要精细交互的应用来说是一个非常有用的特性,例如地图滚动、文档浏览等场景。本文将详细介绍在鸿蒙 Next 中如何使用新增的鼠标轴事件。 开发步骤 环境准备 在开始开发之前&#x…...

多模态大语言模型arxiv论文略读(八十一)
What is the Visual Cognition Gap between Humans and Multimodal LLMs? ➡️ 论文标题:What is the Visual Cognition Gap between Humans and Multimodal LLMs? ➡️ 论文作者:Xu Cao, Bolin Lai, Wenqian Ye, Yunsheng Ma, Joerg Heintz, Jintai …...

3.4/Q2,Charls最新文章解读
文章题目:Associations between reversible and potentially reversible cognitive frailty and falls in community-dwelling older adults in China: a longitudinal study DOI:10.1186/s12877-025-05872-2 中文标题:中国社区老年人可逆性和…...

通过觅思文档项目实现Obsidian文章浏览器在线访问
觅思文档项目开源地址 觅思文档项目开源地址:https://gitee.com/zmister/MrDoc 觅思文档部署步骤概览 服务器拉取代码: git clone https://gitee.com/zmister/mrdoc-install.git && cd mrdoc-install && chmod x docker-install.sh &a…...
Python列表全面解析:从入门到精通
文章目录 Python列表全面解析:从入门到精通一、列表基础1. 什么是列表?2. 列表特性总结表 二、列表的基本操作(基础)1. 访问元素2. 修改列表 三、列表的常用方法(基础)1. 添加元素的方法2. 删除元素的方法3. 查找和统计方法4. 排序和反转 四、列表的高级…...

5月18总结
一.算法题总结 1. 解题思路:对于这个题,我最开始想到就是二分,但是头痛的是有三个解,如果我在-100到100之间二分,那么只能得出一个解,然后我就想了一下,这个要求精度,那么0.01这么小…...
赋予AI更强的“思考”能力
刚刚!北大校友、OpenAI前安全副总裁Lilian Weng最新博客来了:Why We Think 原文链接:Why We Think by Lilian Weng 这篇文章关注:如何让AI不仅仅是“知道”答案,更能“理解”问题并推导出答案。通过赋予AI更强的“思…...

Linux Bash | Capture Output / Recall
注:本文为 “Linux Bash | Capture Output / Recall” 相关文章合辑。 英文引文,机翻未校。 中文引文,略作重排。 Automatically Capture Output of the Last Command Into a Variable Using Bash 使用 Bash自动将最后一个命令的输出捕获到…...

2025/5/18
继续研究一下大佬的RAG项目。开始我的碎碎念。 RAG可以分成两部分:一个是问答,一个是数据处理。 问答是人提问,然后查数据库,把查的东西用大模型组织成人话,回答人的提问。 数据处理是把当下知识库里的东西…...

基于Quicker构建从截图到公网图像链接获取的自动化流程
写在前面:本博客仅作记录学习之用,部分图片来自网络,如需引用请注明出处,同时如有侵犯您的权益,请联系删除! 文章目录 前言预备内容转webp程序PicGo设置Quicker设置视频演示总结互动致谢参考 前言 在自建博…...

LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项
LeetCode算 法 实 战 - - - 双 指 针 与 移 除 元 素、快 慢 指 针 与 删 除 有 序 数 组 中 的 重 复 项 第 一 题 - - - 移 除 元 素方 法 一 - - - 双 重 循 环方 法 二 - - - 双 指 针方 法 三 - - - 相 向 双 指 针(面 对 面 移 动) 第 二 题 - - -…...

uniapp自定义日历计划写法(vue2)
文章目录 uniapp自定义日历计划写法(vue2)1、效果2、实现源码前言:我们有时候需要实现的日历找不到相应的插件的时候,往往需要手动去写一个日历,以下就是我遇到这样的问题时,手搓出来的一个解决方案,希望可以帮助到更多的人。创作不易,请多多支持uniapp自定义日历计划写…...

Java IO框架
I/O框架 流 流的分类: 按方向: 输入流:将存储设备的内容读入到内存中 输出流:将内存的内容写入到存储设备中 按单位: 字节流:以字节为单位,可以读取所有数据 字符流:以字符为单…...

数据库2——查询
查询 学习内容学习感受 学习内容 一、实验目的与要求: 1、掌握SQL单表及多表之间的查询 2、掌握统计及分组函数 二、实验内容: 1.简单查询 ① 从fruits表中检索s_id为100的供货商所供货的水果名和价格 源码: SELECT f_name, f_price FROM…...
Mamba LLM 架构简介:机器学习的新范式
Mamba LLM 架构简介:机器学习的新范式 探索 Mamba LLM 的强大功能,Mamba LLM 是来自一流大学的变革性架构,重新定义了 AI 中的序列处理。语言模型是一种经过训练的机器学习模型,用于在自然语言上执行概率分布。它们的架构主要由多…...

Android 性能优化入门(一)—— 数据结构优化
1、概述 一款 app 除了要有令人惊叹的功能和令人发指交互之外,在性能上也应该追求丝滑的要求,这样才能更好地提高用户体验: 优化目的性能指标优化的方向更快流畅性启动速度页面显示速度(显示和切换)响应速度更稳定稳定性避免出现 应用崩溃&…...

数据库中的锁机制
目录 数据库中的锁机制:原理、分类与实际案例详解 一、数据库锁的核心作用与基本概念 1.1 为什么需要数据库锁? 1.2 锁的分类 二、锁机制的实现与典型场景 2.1 共享锁(Shared Lock) 工作原理 适用场景 代码示例(MySQL) 案例分析 2.2 排他锁(Exclusive Lock) …...

【网络入侵检测】基于Suricata源码分析运行模式(Runmode)
【作者主页】只道当时是寻常 【专栏介绍】Suricata入侵检测。专注网络、主机安全,欢迎关注与评论。 1. 概要 👋 在 Suricata 中抽象出线程、线程模块和队列三个概念:线程类似进程,可多线程并行执行操作;监听、解码、检…...
AI日报 - 2025年05月19日
🌟 今日概览 (60秒速览) ▎🤖 大模型前沿 | GPT-5传闻再起,将基于全新模型构建,与GPT-4彻底分离;Claude 3.7 Sonnet系统提示泄露,揭示其主动引导对话、多语言支持及安全新特性;研究指出直接复用…...
Spring源码主线全链路拆解:从启动到关闭的完整生命周期
Spring源码主线全链路拆解:从启动到关闭的完整生命周期 一文看懂 Spring 框架从启动到销毁的主线流程,结合原理、源码路径与伪代码三位一体,系统学习 Spring 底层机制。 1. 启动入口与环境准备 原理说明 Spring Boot 应用入口是标准 Java 应…...

Linux常用命令(十四)
目录 vi编辑器命令 1-编辑模式 1)准备一个txt文件并且进入vi 2)按i进入编辑模式 3)按o进入编辑模式 4)按a进入编辑模式 2-底行模式 1)退出vim 2)撤销上次操作 3)设置行号底行模式 4ÿ…...

规则联动引擎GoRules初探
背景说明 嵌入式设备随着物联网在生活和生产中不断渗透而渐渐多起来,数据的采集、处理、分析在设备侧的自定义配置越来越重要。一个可通过图形化配置的数据处理过程,对于加速嵌入式设备的功能开发愈发重要。作为一个嵌入式软件从业者,笔者一…...

基于OpenCV中的图像拼接方法详解
文章目录 引言一、图像拼接的基本流程二、代码实现详解1. 准备工作2. 特征检测与描述detectAndDescribe 函数详解(1)函数功能(2)代码解析(3)为什么需要这个函数?(4)输出数…...