《系统架构设计师教程(第2版)》第9章-软件可靠性基础知识-04-软件可靠性设计

文章目录

  • 1. 容错设计技术
    • 1.1 恢复块设计
    • 1.2 N版本程序设计
    • 1.3 冗余设计
  • 2. 检错技术
  • 3. 降低复杂度设计
  • 4. 系统配置中的容错技术
    • 4.1 双机热备技术
      • 4.1.1 双机热备模式
      • 4.1.2 双机互备模式
      • 4.1.3 双机双工
    • 4.2 服务器集群技术

1. 容错设计技术

1.1 恢复块设计

  • 恢复块设计
    • 选择一组程序的操作作为容错设计单元
    • 从而把普通的程序块变成恢复块
  • 恢复块
    • 动态冗余
    • 可以是模块、过程、子程序、程序段等
    • 恢复过程
      • 包含若干个功能相同、设计差异的程序块文本
      • 每一时刻有一个文本处于运行状态
    • 一旦该文本出现故障,则用备份文本加以替换

1.2 N版本程序设计

  • 概述
    • 设计出多个不同版本(或模块)
    • 实行多数表决
  • 目的:防止其中某一软件版本提供错误的服务
  • 注意点:
    • 使软件的需求说明具有完全性和精确性

      保证第二条“不相关性”的前提

    • 设计全过程的不相关性

      它要求各个不同的软件设计人员彼此不交流,程序设计使用不同的算法、不同的编程语言、不同的编译程序、不同的设计工具、不同的实现方法和不同的测试方法

1.3 冗余设计

  • 概述:
    • 在一套完整的软件系统之外
    • 设计一种不同路径、不同算法或不同实现方法的模块或系统作为备份
    • 在出现故障时可以使用冗余的部分进行替换,从而维持软件系统的正常运行。

2. 检错技术

  • 应用
    • 无须在线容错或不能采用冗余设计技术的部分
    • 且对可靠性要求较高,故障后果严重
  • 实现:在软件出现故障后能及时发现并报警
  • 设计时着重考虑的要素
    • 检测对象
      • 检测点:容易出错的地方、出错对软件系统影响较大的地方
      • 检测内容:选取那些有代表性的、易于判断的指标
    • 检测延时:从软件发生故障到被自检出
    • 实现方式
      • 判断返回结果
      • 计算运行时间:如果某个模块或函数运行超过预期的时间,可以判断出现故障
      • 置状态标志位
    • 处理方式:停机、部分停止

3. 降低复杂度设计

  • 软件复杂性组成:
    • 模块复杂性
      • 模块内部数据流向
      • 程序长度
    • 结构复杂性:不同模块之间的关联程度
  • 意义:
    • 与软件可靠性有着密切的关系
    • 是产生软件缺陷的重要根源
  • 其设计的思想
    • 在保证实现软件功能的基础上
    • 简化软件结构,缩短程序代码长度,优化软件数据流向
    • 从而提高软件可靠性。

4. 系统配置中的容错技术

4.1 双机热备技术

  • 概述:
    • 是一种软硬件结合的较高容错应用方案
    • 组成:
      • 两台服务器系统:安装操作系统和相应程序
      • 一个外接共享磁盘阵列柜:数据和数据备份
      • 相应的双机热备份软件

4.1.1 双机热备模式

  • 概述
    • Active/Standby方式
    • 实现:
      • Active 服务器处于工作状态
      • Standby服务器处于监控准备状态
      • 数据同时写入各节点
    • 切换:
      • 当 Active 服务器出现故障的时候
      • 通过软件诊测或手工方式将 Standby机器激活
  • 缺点:备机存在资源浪费

4.1.2 双机互备模式

  • 概述:
    • 实现:
      • 两个相对独立的应用在两台机器同时运行
      • 彼此均设为备机
    • 切换:
      • 当某一台服务器出现故障时,另一台服务器可以在短时间内将故障服务器的应用接管过来
  • 缺点:对服务器的性能要求比较高

教材里说的不是很清楚,这里我补充一下:双机互备实际是在双机热备的基础上的。按照双机热备,两个程序需要四台服务器,但是双机互备只用两台服务器:每台上安装一个服务,另一台作为它的备机。

4.1.3 双机双工

  • 概述:两台服务器均处于活动状态,同时运行相同的应用,
  • 优势:
    • 保证整体系统的性能
    • 实现了负载均衡
    • 互为备份
  • 应用: Web服务器、FTP服务器等

4.2 服务器集群技术

  • 概述
    • 指一组相互独立的服务器在网络中组合成为单一的系统工作
    • 并以单一系统的模式加以管理
    • 为客户提供高可靠性的服务
    • 集群内各结点服务器通过内部局域网相互通信
  • 故障转移:
    • 节点故障:故障节点的服务被其他节点接管
    • 应用服务故障:应用被重启,或由其他节点的服务接管

在这里插入图片描述

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

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

相关文章

Maven:<dependencyManagement>:依赖集中管理

dependencyManagement Maven &#xff1c;dependencyManagement&#xff1e;&#xff0c;请介绍一下 在Apache Maven构建工具中&#xff0c;<dependencyManagement> 是一个非常重要的元素&#xff0c;用于在一个项目或一组项目的顶级POM&#xff08;Project Object Model…

TCP/IP协议—TCP

TCP/IP协议—TCP TCP协议TCP通信特点TCP技术概念TCP定时器 TCP头部报文TCP连接三次握手&#xff08;建立连接&#xff09;四次挥手&#xff08;释放连接&#xff09;连接状态 TCP协议 传输控制协议&#xff08;TCP&#xff0c;Transmission Control Protocol&#xff09;是一种…

Springboot集成Ehcache3实现本地缓存

如果只需要在单个应用程序中使用本地缓存&#xff0c;则可以选择Ehcache&#xff1b;它支持内存和磁盘存储&#xff0c;这里不以注解方式演示&#xff0c;通过自己实现缓存管理者灵活控制缓存的读写&#xff1b; 1、引入相关依赖 <!-- ehcache3集成start --><depende…

苹果在中国市场衰退,全球市场跌幅最大,难怪慌忙大降价

日前市调机构IDC公布了今年一季度全球市场的手机品牌排名&#xff0c;数据显示苹果的跌幅最大&#xff0c;说明它不仅在中国市场衰退&#xff0c;在全球市场也出现衰退&#xff0c;如此也就不奇怪苹果史无前例的在3月份对iPhone15降价1500元促销了。 数据显示一季度苹果的出货量…

阿里云服务器公网带宽按固定和按使用流量怎么选?哪个优惠?

阿里云服务器的公网带宽计费模式分为“按固定带宽”和“按使用流量”&#xff0c;有什么区别&#xff1f;按固定带宽是指直接购买多少M带宽&#xff0c;比如1M、5M、10M、100M等&#xff0c;阿里云直接分配用户所购买的带宽值&#xff0c;根据带宽大小先付费再使用&#xff1b;…

k8s控制器(五)_____DaemonSet

DaemonSet控制器 DaemonSet控制器是Kubernetes中的一种控制器&#xff0c;用于确保集群中的每个节点都运行一个Pod的副本。它通常用于在整个集群中部署一些系统级别的服务&#xff1a; 在每一个node节点运行一个存储服务&#xff0c;例如gluster&#xff0c;ceph。在每一个no…

数据可视化高级技术Echarts(桑基图入门)

目录 一、什么是桑基图 二、基本特征 三、设计注意事项 四、使用Echarts进行初级绘制 1.首先不能忘记五个基本步骤 2.绘制的时需要将图像类型series.type设定为sankey类型。 一、什么是桑基图 桑基图&#xff08;Sankey diagram&#xff09;&#xff0c;即桑基能量分流图&…

2024很漂亮的个人主页HTML源码

源码介绍 很漂亮的个人主页HTML源码&#xff0c;源码由HTMLCSSJS组成&#xff0c;记事本打开源码文件可以进行内容文字之类的修改&#xff0c;双击html文件可以本地运行效果&#xff0c;也可以上传到服务器里面 截图效果 源码下载 很漂亮的个人主页HTML源码

[大模型]浦语灵笔图文理解创作

浦语灵笔图文理解&创作 环境准备 首先在 AutoDL 上租一台显卡驱动支持 11.7 以上的双卡 3090 机器. 在选择镜像是选择 Miniconda --> conda3 --> 3.8(ubuntu20.04)–> 11.6 打开 jupyter lab 中的终端&#xff0c;首先运行以下命令安装 PyTorch 2.0.1 # 升级pi…

1043: 利用栈完成后缀表达式的计算

解法&#xff1a; #include<iostream> #include<stack> using namespace std; int main() {char a;stack<int> sk;while (cin >> a && a ! #) {if (a > 0 && a < 9) {sk.push(a - 0);}else {int num2 sk.top();sk.pop();int n…

数字乡村创新实践探索农业现代化与乡村振兴新路径:科技赋能农村全面振兴与农民福祉新纪元

目录 引言 一、数字乡村与农业现代化新路径 1、智慧农业引领农业现代化 2、农业产业链的数字化转型 二、数字乡村与乡村振兴新路径 1、农村信息化水平的提升 2、农村治理模式的创新 三、科技赋能农村全面振兴与农民福祉新纪元 1、提升农业生产效益与农民收入 2、促进…

H.265视频直播点播录像EasyPlayer.js流媒体播放器用户常见问题及解答

EasyPlayer属于一款高效、精炼、稳定且免费的流媒体播放器&#xff0c;可支持多种流媒体协议播放&#xff0c;无须安装任何插件&#xff0c;起播快、延迟低、兼容性强&#xff0c;使用非常便捷。 今天我们来汇总下用户常见的几个问题及解答。 1、EasyPlayer.js播放多路H.265视…

.NET Framework安装失败的原因及解决方法

.NET Framework安装失败的原因及解决方法 大家好我是艾西&#xff0c;一个做服务器租用的游戏爱好者兼网络架构系统环境问题网络工具人。在我们平时使用PC安装某些程序会出现.NET Framework缺失的提示&#xff0c;那么也会有很多的小伙伴搞不懂什么原因导致的&#xff0c;这个问…

hadoop编程之词频统计

数据集实例 java代码&#xff0c;编程 实例 我们要先创建三个类分别为WordCoutMain、WordCoutMapper、WordCoutReducer这三个类 对应的代码如下 WordCoutMain import java.io.IOException; import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.Pat…

wps导出pdf文献引用不能跳转解决办法

问题描述 本科论文参考文献使用wps设置交叉引用&#xff0c;但导出pdf后无法跳转引用 尝试 用office word打开文件word版跳转没有问题&#xff0c; 另存为pdf或导出pdf。 但是pdf版跳转完全错误。 16跳到14.但是总体而言都是跳到包含该序号的页 要求不高的话也可以&#x…

文件上传App,H5,小程序多端兼容

插件地址&#xff1a;https://ext.dcloud.net.cn/plugin?id5459 下载lsj-upload插件 代码如下 结构 <lsj-upload :option"option" :size"size" :formats"formats" :debug"debug":instantly"instantly" change"…

Redis中的订阅发布(三)

订阅发布 发送消息 当一个Redis客户端执行PUBLISH 命令将消息message发送给频道channel的时候&#xff0c;服务器需要执行以下 两个动作: 1.将消息message发送给channel频道的所有订阅者2.如果一个或多个模式pattern与频道channel相匹配&#xff0c;那么将消息message发送给…

PyPDF2,一个超实用的 Python 库!

更多Python学习内容&#xff1a;ipengtao.com 大家好&#xff0c;今天为大家分享一个超实用的 Python 库 - pypdf。 Github地址&#xff1a;https://github.com/py-pdf/pypdf PDF&#xff08;Portable Document Format&#xff09;是一种广泛用于文档传输和打印的文件格式&…

Hive概述与基本操作

一、Hive基本概念 1.什么是hive? &#xff08;1&#xff09;hive是数据仓库建模的工具之一 &#xff08;2&#xff09;可以向hive传入一条交互式的sql,在海量数据中查询分析得到结果的平台 2.Hive简介 Hive本质是将SQL转换为MapReduce的任务进行运算&#xff0c;底层由HDFS…

【翻译】再见, Clean Code!

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 【翻译】再见, Clean Code!正文那是一个深夜次日早晨这只是一个阶段 【翻译】再见…