软考 系统架构设计师系列知识点之软件可靠性基础知识(2)

接前一篇文章:软考 系统架构设计师系列知识点之软件可靠性基础知识(1)

所属章节:

第9章. 软件可靠性基础知识

第1节 软件可靠性基本概念

9.1 软件可靠性基本概念

9.1.1 软件可靠性定义

软件可靠性(Software Reliability)是软件产品在规定的条件下和规定的时间区间内完成规定功能的能力。规定的条件是指直接与软件运行相关的、使用该软件的计算机系统的状态和软件的输入条件,或统称为软件运行时的外部输入条件;规定的时间区间是指软件的实际运行时间区间;规定功能是指为提供给定的服务,软件产品所必须具备的功能。

软件与硬件有很多不同点,但从可靠性的角度来看,它们主要有如下4个不同点:

(1)复杂性

(2)物理退化

(3)唯一性

(4)版本更新速度

1983年,美国IEEE计算机学会对"软件可靠性"做出了明确的定义,随后,此定义经美国标准化研究所批准为美国的国家标准。1989年,我国国家标准GB/T-11457也采用了这个定义。这个定义就是:在规定的条件下,在规定的时间内,软件不引起系统失效的概率,该概率是系统输入和系统使用的函数,也是软件中存在的缺陷函数;系统输入将确定是否会遇到已存在的缺陷(如果缺陷存在的话)。

简而言之,就是在规定的时间周期内,在所述条件下,程序执行所要求的功能的能力。显而易见,美国IEEE计算机学会关于"软件可靠性"的定义仍然沿用了"产品可靠性"的定义,但有了更具体的定位和更深入的描述。

下面来分析一下软件可靠性的框架性定义。

(1)规定的时间

软件可靠性只是体现在其运行阶段,所以将"运行时间"作为"规定的时间"的度量。"运行时间"包括软件系统运行后工作与挂起(开启但空闲)的累计时间。由于软件运行的环境与程序路径选取的随机性,软件的失效为随机事件,所以运行时间属于随机变量。

(2)规定的条件

规定的条件主要指软件的运行环境。它涉及软件系统运行时所需的各种支持要素,如支持硬件平台(服务器、台式机和网络平台等)、操作系统、数据库管理系统、中间件,以及其它支持软件、输入数据格式和范围及操作规程等。不同的环境条件下,软件的可靠性是不同的,具体地说,规定的环境条件主要是描述软件系统运行时计算机的配置情况及对输入数据的要求,并假定其它一切因素都是理想的。有了明确规定的环境条件,还可以有效地判断软件失效的责任在用户放还是开发方。

(3)所要求的功能

软件可靠性还与规定的任务和功能有关。由于要完成的任务不同,软件的运行情况会有所区别,则调用的子模块就不同(包括程序选择路径不同),其可靠性也可能不同。所以,要准确度量软件系统的可靠性,必须先明确其任务和功能。

(4)"软件可靠性"定义具有以下特点

1)用内在的"缺陷"和外在的"失效"关系来描述可靠性,更能深刻地体现软件的本质特点。

2)定义使人们对软件可靠性进行量化评估成为可能。对于软件的可靠性这样一个质量特性,很难用一个明确直观的数值去体现。而根据这个定义,人们有可能通过分析影响可靠性的因素,用函数的形式,按照不同的目的建立各种数学模型去分析软件可靠性。

3)用概率的方法去描述可靠性是比较科学的。前面讲到,软件失效是随机的外部表现,完全是有一个随机事件,而软件缺陷是软件固有的没有损耗的内在特点。定义用规定时间内其操作不出现软件失效的概率,也就是输入未碰到软件缺陷的概率来描述可靠性,这种方法就是用概率来描述纯粹的随机事件,是比较合理的,也是可行的。

至此,"9.1.1 软件可靠性定义"的全部内容就讲解完了。更多内容请看下回。

相关推荐
C澒5 小时前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
C澒6 小时前
前端分层架构实战:DDD 与 Clean Architecture 在大型业务系统中的落地路径与项目实践
前端·架构·系统架构·前端框架
皮卡丘不断更9 小时前
告别“金鱼记忆”:SwiftBoot v0.1.5 如何给 AI 装上“永久项目大脑”?
人工智能·系统架构·ai编程
成茂峰9 小时前
软考高级·系统架构设计师 | 四、信息技术安全知识
安全·信息安全·系统架构·架构设计师
牵牛老人10 小时前
【Qt 开发后台服务避坑指南:从库存管理系统开发出现的问题来看后台开发常见问题与解决方案】
开发语言·qt·系统架构
行走正道12 小时前
CANN仓库日志系统架构 分级日志与性能开销优化源码解读
系统架构·cann
若风的雨1 天前
【deepseek 学习】RT-Thread 简介
系统架构
学历真的很重要1 天前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
智算菩萨2 天前
【网络工程师入门】DNS域名系统的深度解读与实践应用指南
网络·网络协议·系统架构
Coder_Boy_2 天前
企业级项目高并发监控场景-Spring Boot 集成 Graphite & InfluxDB 实战文档
java·spring boot·后端·系统架构