需求分析引言:架构漫谈(二)非功能性需求

news2024/9/22 1:40:09

上一篇文章,简要介绍了架构的概念和架构设计流程,并简单介绍了需求分析的内容,
并在最后指出:需求分析的产出物,要包括非功能性需求,常见的非功能性需求如下:

  • 完成任务的速度
  • 结果的精度
  • 操作的安全性
  • 产品的容量
  • 允许的值的范围
  • 吞吐量,例如tps
  • 资源使用的效率
  • 可靠性
  • 容错能力和健壮性
  • 伸缩性
  • 可扩展性

红色部分是常见项目的重点关注点(注:根据项目背景不同而不同,比如安全产品最重要的是安全性)。
对一个项目而言,更高的非功能性要求,代表着更高的系统复杂度、更高的成本投入(时间成本、人力成本、硬件及维护成本),需要根据公司/项目/人力/环境等背景因素综合评估。

非功能性需求

需求分析后输出的非功能性需求,必须可量化,基本要求:

  • 非功能性需求必须无二义性,可理解,可测试。
  • 标准先行,否则设计、实现或测试将没有依据。
  • 所有需求都可测量,测量的尺度是用于测试产品符合程度的单位。

作为架构设计人员,对非功能性需求,要关注的最重要的点:不能度量的需求不是真需求

  • 度量的定义如下:
    • 指在软件开发过程中,通过数据收集和数据分析,来评估软件质量和性能的过程。
      这个过程可以帮助开发团队了解软件的现状,开发的进展,发现潜在的问题和风险,并对软件进行定量的评估,及制定改进措施。

无效的非功能性需求举例:

  • 必须支持高并发:系统希望能随1000用户并发,还是10000用户并发?
  • 接口响应要尽可能快:可接受的响应时间100毫秒?200毫秒?还是1秒?有5%的用户超过1秒能不能接受?

下面逐一介绍一下这些非功能性需求的概念,以及部分度量指标,在做架构设计应该评估和采集这些指标,以评估当前系统情况,及未来的优化方向。

1、完成任务的速度

  • 解释:
    即性能/效率,通常是指软件的“时间/空间”效率,而不仅是指软件的运行速度。
  • 度量指标:
    • 响应时间(平均时间/最大时间/95分位时间)
    • CPU使用率
    • 缓存命中率
    • IO次数/IO时长(磁盘IO/网络IO)
    • 最大连接数/并发数
  • 示例:
    用户单次操作的最大响应时间不得高于2秒;
    产品必须每10秒读取一次传感器的值;
    系统应该在0.25秒内识别出一架飞机是敌人还是友军;
    云端配置更新后,产品必须在1分钟内更新到最新配置并完成刷新。
  • 数据举例:
    一个2.5GHz的CPU,每个CPU时钟周期是0.4纳秒,
    假设每个CPU时钟周期为1秒,常见的计算机耗时及相对1秒时钟周期耗时的对比数据如下:
    在这里插入图片描述
    对比的结果还是挺触目惊心的吧,哈哈。
  • 内存是千兆网速的200倍,所以能用内存缓存时,就不要考虑Redis了;
  • 上下文切换也很耗费CPU性能,所以IO不多的任务,就不要考虑多线程了;
  • 尽快更换SSD硬盘吧;
  • 做了跨数据中心高可用时,尽量保证每个中心都有整套服务,确保同一个数据中心内互访。

2、结果的精度

  • 解释:
    通常指软件输出的结果(例如计算结果、测量结果、数据分析结果等)的精度要求。
  • 度量指标:
    其衡量标准是输出值与真实值之间的误差大小。
  • 说明:
    结果的精度在多数系统内一般不会特别体现出来,但是在一些行业内,精度是特别重要的指标:
    • 银行系统:虽然银行给用户的利息是精确到分,但是内部的计算,必须至少精确到厘,甚至更高的精度,才能保证数据汇总正确;
    • 自动驾驶系统:自动驾驶系统对精度的重要性显然是极高的,障碍物与车的距离判断准确与否,避免重影等非障碍物误判等。
      通常精度用范围区间指示,如 ±1厘米
  • 注:
    所有涉及金额的存储和计算,都建议采用整数存储,例如普通人民币计算,写入DB时,用分为单位写入;
    上面说到的利率计算,可以用厘为单位写入DB及内存计算,以避免二进制问题带来的小数精度问题。

3、操作的安全性

  • 解释:
    指保护系统免受意外访问、破坏和误用的能力。包括:认证和授权、访问控制、数据保护、通信安全、安全日志、定期审计等。
    主要通过方案评审和测试用例进行确认,如:
    密码复杂度、两步验证的算法安全性、角色权限和访问控制策略等、数据加密保护方案评估、备份频率和完整性、灾备方案、通信加密强度、审计日志的完整性和保密性、安全审计的频率和深度
  • 备注:
    • 加密的强度应当充分考虑,例如常规的MD5加盐已经不够安全了,比较好的作法是:MD5( MD5(明文+用户特定盐值1) + 用户特定盐值2)
    • 涉及金额的数据写入DB时,应当增加一个校验字段,根据该行的所有字段进行Hash加盐后计算获得,
      使用时,需要校验该字段,如果不匹配应当禁止该笔交易,避免内部员工篡改数据;
    • 安全性要求高的系统,应部署独立的加解密服务,传入用户ID + 源数据,该服务根据用户ID获取特定密钥加密,返回加密后的数据;
    • 所有敏感数据查看/操作,均应二次验证身份;所有数据导出,均应脱敏处理;
    • 高安全性要求的产品线,应当跟其它产品线网络隔离,避免通过其它产品漏洞,从内网攻击本产品。

4、产品的容量

  • 解释:
    通常是指软件在一定时间内的数据容量要求。
  • 度量指标:
    根据软件要求输出,如已注册用户数;已存储文件大小
  • 示例:
    一个月内系统能支持到1万注册用户,一年内能支撑达到10万注册用户;
    一个月内S3存储能支持10万文件/100GB,一年内能支撑达到10亿文件/5PB。

5、允许的值的范围

  • 解释:
    软件系统在使用过程中,对一些输入数据的范围限制。
  • 示例:
    用户姓名的最大长度
    交易金额的最小值和最大值,比如餐厅的菜品单价不允许超过1万元

6、吞吐量

  • 解释:
    通常是指软件在单位时间内传输数据的数量。
  • 度量指标:
    • TPS:Transactions Per Second(每秒传输的事物处理个数)
    • QPS:Queries Per Second(每秒查询次数)
      可以理解为服务器收到一次请求,就增加一次QPS。
      假设打开网站首页,向服务器发起了3个请求:首页、登录状态、新闻列表,
      此时TPS加1,QPS加3
    • RT:Response Time(每次请求的响应时间)
    • 并发数:系统同时处理的请求数
      比如某个服务收到了100个请求,都还在处理中没有响应,则此时并发就是100
      很多文章说 并发数 = QPS * 平均响应时间,这其实是不准确的,这是2个不同的性能指标,
      确实:并发越高,可能会导致响应时间变长,QPS也确实会相应变小,
      但是这些性能指标,都跟服务器状态、网络状态、磁盘等的影响,并不能直接互相转换。
  • 示例:
    支付系统TPS达到4000以上
    商城系统TPS达到2000以上, QPS达到10000以上
    营销系统并发数达到10000以上
    订单系统API的RT在100ms以内

7、资源使用的效率

  • 解释:
    通常指定特定硬件组件上的使用量、占用率、释放情况,如需要4核以上CPU、16G以上内存;需要千兆带宽。
  • 度量指标:
    • CPU占用时长
    • 内存使用量
    • 磁盘占用空间
    • IO均值、峰值、总传输数据量等
    • TPS单位时间内能处理完
  • 说明:
    通过良好的架构设计、较优的算法实现可以优化资源使用效率。
    特殊场景无法横向扩容机器时,可以通过简单的单机硬件配置提升来优化。

8、可靠性

  • 解释:
    指的是产品在规定的时间内,在规定的条件下,完成预定功能的能力。
  • 度量指标:
    • MTBF——全称是Mean Time Between Failure,即平均故障间隔时间。
    • MTTR——全称是Mean Time To Repair,即平均故障恢复时间。
    • MTTF——全称是Mean Time To Failure,即平均无故障时间。
    • 可用性Availability=UpTime/(UpTime+DownTime)=MTBF / (MTBF + MTTR)
  • 示例:
    服务平均无故障时间占比应该高于99.9%, 5分钟内请求错误率高于1%即判定为故障。
  • 注:
    • 有些文章说MTBF = MTTF + MTTR,
      我的理解,MTBF是平均故障间隔时间,指系统正常运行的平均时间,不应该包含MTTR。
    • MTTF是指系统平均能够正常运行多长时间,才发生一次故障。系统的可靠性越高,平均无故障时间越长。
      后续我再会专题写一篇文章,介绍可靠性和可用性。

9、容错能力和健壮性

  • 解释:
    指系统在面对错误和异常情况时的处理能力和稳定性。
  • 度量指标:
    通常通过开发规范约束、代码检测质量、设计评审来衡量;
    以及系统崩溃次数、错误日志统计等数据评估
  • 示例:
    用户输入任意数据,系统均能正常处理或提示错误,不会崩溃或产生错误响应,生成错误数据。
    系统出现崩溃时,能记录异常信息,以供问题排查,并能有效响应用户(服务降级)

10、伸缩性

  • 解释:
    不改变系统的情况下,通过简单升降配置/增减服务器来调整系统处理业务的能力。
  • 度量指标:
    • 响应时间:用户数增长/请求数增加,响应时间是否随之增加
    • 错误响应数:用户数增长/请求数增加,错误响应是否随之增加,如超时,网络错误,限流错误等
  • 示例:
    在访问量平滑增长的情况下,能自动扩容达到服务可用性不受影响;
    在访问量下降的情况下,能自动缩容以降低成本,且服务可用性不受影响;

11、可扩展性

  • 解释:
    新增产品或需求时,实现对现有产品无影响,透明上线新产品的能力。
  • 示例:
    系统支持蓝绿发布、滚动发布、灰度发布。

参考知识

对于非功能性需求,已经有不少的业界标准可供学习和参考,提供了更多的非功能性需求和说明,如:

  • Jim McCall 软件质量模型(1977 年)

  • Barry W. Boehm 软件质量模型(1978 年)

  • FURPS/FURPS+ 软件质量模型

  • R. Geoff Dromey 软件质量模型

  • ISO/IEC 9126 软件质量模型(1993 年)

  • ISO/IEC 25010 软件质量模型(2011 年)

下面介绍2个目前比较常用的软件质量模型,建议认真阅读理解一下:

软件质量模型 ISO/IEC 25010

由ISO(国际标准化组织) 和 IEC(国际电工委员会) 联合制订的软件质量标准,替代 ISO/IEC 9126标准;
详细介绍参考: https://iso25000.com/index.php/en/iso-25000-standards/iso-25010
在这里插入图片描述

软件质量模型 FURPS/+

FURPS 模型最早是由惠普公司的罗伯特·格雷迪(Robert Grady)及卡斯威尔(Caswell)提出,后来由 Rational Software 进行扩展至 FURPS+。
详细介绍可以参考:https://sceweb.uhcl.edu/helm/RationalUnifiedProcess/process/workflow/requirem/co_req.htm
在这里插入图片描述

结语

上面简单介绍了一些非功能性需求和相关指标,后面两篇文章,会对软件系统比较关注的可用性 和 性能优化进行介绍。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/673860.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL实战解析底层---为什么表数据删掉一半,表文件大小不变

目录 前言 参数innodb_file_per_table 数据删除流程 重建表 Online 和 inplace 前言 数据库占用空间太大,我把一个最大的表删掉了一半的数据,怎么表文件的大小还是没变?这与数据库表的空间回收有关这里还是针对MySQL中应用最广泛的InnoD…

结构型设计模式07-享元模式

🧑‍💻作者:猫十二懿 ❤️‍🔥账号:CSDN 、掘金 、个人博客 、Github 🎉公众号:猫十二懿 享元模式 1、享元模式介绍 享元模式是一种结构型设计模式,旨在**通过共享对象来减少内存使…

CSS弹性布局常用设置

目录 一、单位元素 二、弹性容器 三、常用属性 三、项目实战效果 一、单位元素 vm 1vm 为视口的1% vh 视口高的1% vmin 参照长边 vmax 参照长边 rem 等比缩放 需要设置最外层盒子html设置vw 根字号html的--- font-- 1vm 去适配 初始化 //初始化*{padding: 0;margin: 0}//…

机器学习笔记 - 通过一个例子来快速理解自注意力机制/缩放点积注意力机制

一、一个简单的示例 请看下面的例句:A dog ate the food because it was hungry(一只狗吃了食物,因为它很饿) 例句中的代词it(它)可以指代dog(狗)或者food(食物)。当读这段文字的时候,我们自然而然地认为it指代的是dog,而不是food。但是当计算机模型在面对这两种选…

CVPR首个大模型研讨会顺利召开,吸引超1000支队伍参与文心大模型国际比赛

CVPR 作为计算机视觉和模式识别领域的世界级学术顶会,不仅是学者们展示前沿科技成果的学术会议,也是企业界探索前沿应用的一大平台。近年来,随着大模型技术的爆发式发展,基于大模型技术的创新应用正逐步在产业界释放出巨大价值空间…

网易云信陈丽:做泛娱乐出海新浪潮中的坚实助力者

6 月 16 日下午,在 PAGC 2023 泛娱乐出海论坛上,网易智企副总经理、网易云信总经理陈丽分享了对全球化出海的趋势洞察和未来展望,并介绍了网易云信在帮助泛娱乐出海业务增长方面的探索和实践。 陈丽表示,网易云信志在成为中国开发…

STM32开发——非标协议(DH11+LCD1602)

1.STM32分文件实现代码 编译的总文件夹dh11andlcd,C文件不能跨文件夹查找,新增的分文件,需要都放调用的文件夹下 C文件和H文件理解:H文件是门脸,放在前面给别人的,别人一看就知道有什么东西。C是给内部人用…

记录--新的HTML标签 :search

这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 本文介绍了一种新的HTML元素搜索方法,并提供了一个实用的工具来帮助开发者快速找到所需的元素。这对于那些需要处理大量HTML元素的开发者来说是非常有用的。文章还通过提供一些常见元素的用…

AutoSAR系列讲解(入门篇)1.1-AutoSAR的发展史

一、AutoSAR成员 大体可以分为核心成员、高级成员和发展成员,可以打开AutoSAR官网的成员的介绍界面 所以有兴趣的小伙伴可以稍微了解一下,仅作了解就行,不是什么重要的知识 还有一张大家经常能看见的成员图,如下 二、AutoSAR历史…

国潮之美丨土家族西兰姑娘续写千年非遗传奇

光脚丫,童年时期的行为艺术 还记得儿时的夏夜,姥爷总说:“娃儿呀,光着脚在地上跑,接地气些”。那时只觉得脱掉鞋袜顿时轻松自在,从坡上冲到坡下,几个伙伴乐此不疲。后来长大了,穿着…

盘点一个Python网络爬虫过验证码的问题(方法一)

点击上方“Python爬虫与数据挖掘”,进行关注 回复“书籍”即可获赠Python从入门到进阶共10本电子书 今 日 鸡 汤 低眉信手续续弹,说尽心中无限事。 大家好,我是皮皮。 一、前言 前几天在Python最强王者群【鶏啊鶏。】问了一个Python网络爬虫的…

SSH连接异常:从迷茫到石破天惊的解决之道

文章目录 零:前言一:SSH1.1 SSH的连接类型、方式和端口1.2 常见端口及其类型 二:解决SSH连接异常第一步:欣赏报错,顺藤摸瓜第二步:异常窥探,摸石过河第三步:问题确定,斩首…

测试技术体系

目录: 软件测试分类分层测试体系 1.软件测试分类 软件测试的分类_安全性测试属于功能测试吗_阿瞒有我良计15的博客-CSDN博客 1.单元测试(Unit Testing):单元测试是指对软件的最小可测试单元进行测试,例如一个函数、一…

Cell — 新“出芽”方法为疫苗开发带来优势

在疫苗学中,基于mRNA向体内递送抗原编码基因同基于纳米颗粒向体内递送抗原在应对具有挑战性的病原体方面都显示出巨大的前景。本期的《Cell》中,Hoffmann等人将两种方法相结合,通过调节被许多病毒劫持的相同细胞代谢通路来增强SARS-CoV-2疫苗…

【UCOS-III】自我学习笔记→第27讲→优先级翻转

文章目录 前言实验步骤1.复制二值信号量工程,添加task2和task3,修改任务服务函数名称2.修改开始任务,任务1以及任务2、3的内容3.查看串口现象![在这里插入图片描述](https://img-blog.csdnimg.cn/efa5ee2d92b54fe8be5a419adcf92ead.png) 测试…

STM32速成笔记—DMA

文章目录 一、什么是DMA二、DMA有什么作用三、STM32的DMA3.1 DMA请求3.2 DMA通道3.3 仲裁器 四、DMA配置4.1 DMA配置步骤4.2 DMA结构体成员 五、DMA配置程序5.1 ADC1初始化程序5.2 DMA初始化程序 一、什么是DMA DMA全程Direct Memory Access,即直接存储器访问。简单…

如何保护阿里云服务器免受DDoS攻击和恶意访问?有哪些防护措施?

如何保护阿里云服务器免受DDoS攻击和恶意访问?有哪些防护措施?   [本文由阿里云代理商[聚搜云]撰写]   随着互联网技术的不断发展,网络安全问题日益严峻,保护服务器免受DDoS攻击和恶意访问成为了每个企业和网站建设者的关注重…

W3B x Sui Hacker House|深入了解Sui和Move语言

Web3 Builders(W3B)作为Hacker House的践行者,将于6月23日(周五)早上8点(GMT8)举办首期 W3B x Sui Hacker House 系列活动分享会。本期活动邀请到Sui联合创始人Sam Blackshear(Move语…

【机器学习】机器学习的基本概念

机器学习是我们现在接触人工智能领域首先要去掌握的知识,下面是我学习记录的一些关于机器学习的基础、常见的概念和定义。 目录 机器学习定义 机器学习过程 假设关系 训练数据 损失函数(正向传播) 优化(反向传播&#xff0…

PC市场:寒冬敲响警钟,蓄势待发的复兴之路

近年来,PC市场的增长确实放缓,但这并不意味着它已经进入了寒冬。相反,PC市场正在蓄势待发,寻找复兴之路。 首先,PC市场仍然是一个巨大的市场。尽管移动设备的普及使得一些用户更多地使用手机和平板电脑,但…