软考系统架构师案例分析知识点整理

news2024/10/7 12:29:28

系统规划:包括系统项目的提出预可行性分析;系统方案的制定、评价和改进;新旧系统的分析和比较;现有软件、硬件和数据资源的有效利用;

软件架构设计:XML技术;基于架构的软件开发过程;软件的质量属性;架构(模型)风格;特定领域软件架构;基于架构的软件开发方法;架构评估;软件产品线;系统演化

设计模式:设计模式概念;设计模式的组成;模式和软件架构;设计模式分类;设计模式实现;

系统设计:处理流程设计;人机界面设计;文件涉及;存储设计;数据库设计;网络应用系统的设计;系统运行环境的集成与设计;中间件;应用服务器;性能设计与性能评估;系统转换设计划;

软件系统建模:系统需求、建模的作用以及意义;定义问题(目标、功能、性能)与归结模型(静态结构模型、动态行为模型、物理模型);结构化系统建模;数据流图;面向对象系统建模;统一建模语言(UML);数据库建模;E-R图;逆向工程;

分布式系统设计:分布式通行协议的设计;基于对象的分布式系统设计;基于web的分布式系统设计;基于消息和协同的分布式系统设计;异构分布式系统的互操作性设计;

嵌入式系统设计:实时系统和嵌入式系统特征;实时任务调度和多任务设计;中断处理和异常处理;嵌入式系统的开发设计

系统的可靠性分析与设计:系统故障模型和可靠性模型;系统的可靠性分析与可靠度计算;提高系统可靠性的措施;系统的故障对策和系统的备份与恢复;

系统安全性和保密性设计:系统的访问控制技术;数据的完整性;数据与文件的加密;通信的安全性;系统的安全性设计;

1、 概念类

系统规划

项目计划:包括范围计划、工作范围计划、活动定义、资源需求、资源计划、活动排序、费用估算、进度计划、费用计划;项目辅助计划包括质量计划、沟通计划、人力资源计划、风险计划、采购计划。

虚拟化技术:计算元件在虚拟的基础上运行;有完全虚拟化,准虚拟化,操作系统层虚拟化等;

虚拟化收益:

1、 有效提高服务器资源利用率

2、 支持运行在不同操作系统之上的多个业务共享一台服务器

3、 减少服务器数量,降低硬件成本

4、 节约场地面积,减少能耗

软件架构设计

架构风险:架构设计中潜在的、存在问题的架构决策所带来的隐患

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

权衡点:影响多个质量属性,并且对多个质量属性来说都是敏感点的系统属性

软件质量属性包括:功能性、性能、可用性、可靠性、健壮性、安全性、可修改性、可变性、易用性、可测试性、互操作性

六种质量属性策略:

1、 可用性

错误检测:命令/响应,心跳机制,异常监控

错误恢复:表决(裁决表),主动冗余,被动冗余,备件,状态再同步,检查点/回滚

错误预防:从服务中删除,事物(要么全成功,要么全失败),定期重置,进程监视器

2、 可修改性

局部化修改:维持语义的一致性,预期期望的变更,泛化该模块,限制可能的选择

防止连锁反应:信息隐藏,维持现有的接口,限制通信路径,仲裁者的使用

推迟绑定时间:运行时注册,配置文件,多态,构件更换

3、 性能

资源需求:减少处理时间所需的资源,减少所处理事件的数量,控制资源使用,限制执行时间

资源管理:引入并发,维持数据或计算的多个副本,增加可用资源

资源仲裁:先进/先出,固定优先级,动态优先级调度,静态调度

4、 安全性

抵抗攻击:对用户进行身份验证,对用户进行授权,维护数据的机密性,维护完整性,限制暴露的信息,限制访问

检测攻击:部署入侵检测系统

从攻击中恢复:恢复,识别攻击者

5、 可测试性

输入/输出:记录/回放,将接口—实现分离,优化访问线路/接口

内部监控:当监视器处于激活状态时,记录事件

6、 易用性

运行时:任务模型,用户模型,系统模型

设计时:将用户接口与应用的其余部分分离

支持用户主动:支持用户主动操作

软件架构风格:描述某一类特定应用领域中软件系统组织方式和惯用方式;组织方式描述了系统的组成构建和这些构建的组织方式,惯用模式则反映众多系统共有的结构和语义。

1、 数据流风格

批处理序列:每个处理步骤是一个独立的程序,每一步必须在前一步结束后才能开始,数据必须是完整的,以整体的方式传递

管道/过滤器:每个构件都有一组输入和输出,构件接受数据输入,经过内部处理,然后产生输出数据流。这里构件被称为过滤器,连接件就是数据流传输的管道。

2、 调用/返回风格

主程序/子程序:计算构件作为子程序协作工作,并由一个主程序顺序地调用这些子程序,构件通过共享存储区交换数据。

数据抽象和面向对象:将数据表示和基本操作封装在对象中。

层次结构:构件组织成一个层次结构,每层为上一层提供服务,使用下一层的服务,只能见到与自己邻接的层。

3、 独立构件风格

进程通信:构件是独立的过程,连接件是消息传递。特点是构件通常是命名过程,消息传递的方式可以是点到点、异步或同步方式,及远程过程(方法)调用

事件驱动的系统:构件不直接调用一个过程,而是触发或广播一个或多个事件。构件中的过程在一个或多个事件中注册,当一个事件被触发,系统自动调用在这个事件中注册的所有过程。

4、 虚拟机风格

解释器:一个解释器通常包括完成解释工作的解释引擎,一个包含将被解释的代码的存储区,一个记录解释引擎当前工作状态的数据结构,以及一个记录源代码被解释执行的进度的数据结构。

基于规则的系统:包括规则集、规则解释器、规则/数据选择器及工作内存。

5、 仓库风格

数据库系统:主要有两大类,一个是中央共享数据源,保存当前系统的数据状态;另一个是多个独立处理元素,处理元素对数据元素进行操作。

黑板系统:是一个全局数据库,包含解域的全部状态,是知识源互相作用的唯一媒介。

超文本系统:是一种非线性的网状信息组织方法,以节点为基本单位,链作为节点之间的联想式关联。

6、 复制风格

复制仓库:通过利用多个进程提供相同的服务,来改善数据的可访问 性(accessibility of data)和服务的可伸缩性(scalability of service)。

缓存:复制个别请求的结果,以便可以被后面的请求重用。

控制环路架构风格:将过程输出的定属性维护在一个特定的参考值。

企业服务总线(ESB):是传统中间件技术与XML、Web服务等技术结合的产物,主要支持异构系统集成。ESB基于内容的路由和过滤,具备复杂数据的传输能力,并可以提供一系列的标准接口。

ESB的主要功能:

1、 应用程序的位置透明性

2、 输出协议转换

3、 消息格式转换

4、 消息路由

5、 消息增强

6、 安全支持

7、 监控和管理

设计模式

创建模式:主要用于创建对象,为设计类实例化新对象提供指南

包括:工厂方法(Factory Method)、抽象工厂(Abstract Factory)、单例(Singleton)、构建(Builder)、原型(Prototype)

结构模式:主要用于处理类或对象的组合,对类如何设计以形成更大的结构提供指南

包括:适配器(Adapter)、合成(Composite)、装饰(Decorator)、代理(Proxy)、享元(Flyweight)、门面(Facade)、桥接(Bridge)

行为模式:主要用于描述类或对象的交互以及职责的分配,对类之间交互以及分配责任的方式提供指南

包括:策略(Strategy)、模版方法(Template Method)、迭代器(Iterator)、责任链(Chain of Responsibility)、命令(Command)、备忘录(Mediator)、状态(State)、访问者(Visitor)、解释器(Interpreter)、调停者(Mediator)、观察者(Observer)

系统设计

数据流图:作为一种图形化工具,用来说明业务处理过程、系统边界内所包含的功能和系统中的数据流;

流程图:以图形化的方式展示应用程序从数据输入开始到获得输出为止的逻辑过程,描述处理过程的控制流;

JRP(联合需求分析会议):通过召开一系列高度结构化的分组会议,快速的分析问题、定义需求;

软件系统建模

用例建模:描述参与者和系统之间的主要交互;用例建模可以描述利益相关者所看到的系统行为;

组件建模:确定系统的子系统、模块和组件结构,为子系统、模块分配需求和职责,每个组建元素作为一个自包含的单元,用于开发、部署和执行。

服务建模:提供了通用的应用程序,并将应用程序定义为一组抽象服务接口。

性能建模:是对系统的性能进行度量,为每个组件确定性能指标。包括执行时间、资源使用、开发复杂性、维护复杂性等。

分布式系统设计

嵌入式系统设计

系统的可靠性分析与设计

冷备份:在数据库关闭的情况下,对数据库中的关键文件进行

热备份:在数据库运行的情况下,对数据库中的关键数据进行备份,要求数据库管理系统提供支持

系统安全性和保密性设计

信息系统的安全威胁来自于:

1、 物理环境:对系统所用设备的威胁,如:自然灾害,电源故障,数据库故障,设备被盗等造成数据丢失或者信息泄露

2、 通信链路:传输线路上安装窃听装置或者对通信链路进行干扰

3、 网络系统:由于因特网的开放性、国际性、无安全管理性,对内部网络形成严重的安全威胁

4、 操作系统:操作系统本身的后门或者安全缺陷,如木马和陷阱门

5、 应用系统:网络服务或者用户业务系统安全的威胁,包括应用系统自身漏洞

6、 管理:人员管理和各种安全管理制度

用户认证方式:

1、 用户名和口令认证

2、 基于公钥、签名的认证方式

3、 持卡认证方式

4、 基于人体生物特征的别认证方式

对称加密策略:

机密性:发送者利用对称密钥对要发送的数据进行加密,只有拥有相同密钥的接收者才能正确解密,从而提供机密性;

完整性:发送者根据要发送的数据生成消息摘要,利用对称密钥对消息认证进行加密并附加到数据上发送;接收者使用相同的密钥将对方发送的消息认证码解密,并根据接收到的数据重新生成消息认证码,比较两个认证码是否相同以验证数据的完整性

公钥加密策略:

机密性:发送者利用接受者的公钥对要发送的数据进行加密,只有拥有对应私钥的接收者才能将数据正确解密,从而提供机密性

完整性:发送者根据要发送的数据生成消息摘要,利用自己的私钥对消息认证码加密并且附加到数据上发送;接收者利用对方的公钥将对方发送的消息认证码解密,并根据接收到的数据重新生成消息认证码,比较两个认证码是否相同以验证数据完整性

2、优点缺点类

系统规划

软件架构设计

设计模式

系统设计

区别

数据流图

流程图

处理过程可以并行

某个时间点只能处于一个处理过程

展现系统的数据流

展现系统的控制流

展现全局的处理过程,过程之间计时标准不同

处理过程遵循一致的计时标准

适用于系统分析中的逻辑建模阶段

适用于系统设计中的物理建模阶段

传统系统集成方案

基于Web2.0的Mashup技术

需要传统平台API层的支持,集成过程复杂

仅需要用现有的Web应用程序公开的基于Web的API(Web服务)构建应用程序,集成过程简单

需要采用编程的方式完成系统功能扩展,设计数据存储层、业务逻辑层和表现层

直接使用Mashup技术集成两个或者多个WebAPI,创建新的特性与功能

传统集成方式下的表现层大多采用静态展现技术,当客户端发送请求时,需要刷新整个页面

用Ajax技术调用基于Web的API,浏览器客户端不需要在每次与服务器通行时重新加载整个页面,动态特性强

使用传统的多层企业应用集成技术,涉及不同的集成层次

采用SOA思想集成底层系统,强调功能暴露与服务,以服务形式集成并暴露有系统的能力

软件系统建模

分布式系统设计

分布式数据库的特点有:数据独立性与位置透明性。集中管理和节点自治相结合、支持全局数据库的一致性和可恢复性、复制透明性(适度数据冗余)、易于扩展性。

分布式数据库的优点:

1、 具有灵活的体系结

2、 适应分布式的管理和控制结构

3、 经济性能优越

4、 系统可靠性高,可用性好

5、 局部应用的响应速度快

6、 可扩展性好,易于集成现有系统

缺点:

1、 系统开销大,主要花在通信部分

2、 复杂的存储结构

3、 数据的安全性和保密性较难处理

4、 保持数据一致性算法复杂

分布式数据库中各局部数据库应该满足集中式数据库的基本需求,除此之外还应保证数据库的全局数据一致性,并发操作可串行性,故障的全局可恢复性;

保证方法:

一致性:数据副本一致性,保证分布式事务的ACID属性,故障恢复的一致性

嵌入式系统设计

系统的可靠性分析与设计

备份方式

优点

缺点

冷备份

快速简单,维护方便

备份时,数据库关闭,不能做其他工作

可以恢复到备份时的时间点上

单独使用时,只能恢复到备份时的时间点上,数据丢失

与热备份相结合,实现实时/秒级恢复

不能按数据库中的表或某个用户进行恢复

热备份

备份时数据库仍然可用

如果热备份出错,所得结果不能用于时间点的恢复

可以实现实时/秒级恢复

不能出错,否则可能会引起数据库无法恢复

可对几乎所有数据库实体做恢复,速度快

维护比较困难

系统安全性和保密性设计

3、原则类

系统规划

软件架构设计

设计模式

系统设计

高质量数据流图设计原则:

1、 复杂性最小化原则:DFD分层结构就是把信息划分为晓得且相对独立的一大批子集例子,这样就可以单独考查每一个DFD;

2、 接口最小化原则:在设计模式时,模型中各个元素之间的接口数或者连接数最小化;

3、 数据流一致性原则:过程与过程分解数据流一致,有数据流出就有数据流入;数据流入需要有相应的数据加工;

4、其他

1、电子政务包括:政务信息查询;公共政务办公;政务办公自动化三个应用领域

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

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

相关文章

【算法通关村第一关】链表经典问题

1.两个链表第一个公共子节点 1.这是一道经典的链表问题&#xff1a;输入两条链表&#xff0c;找出他们的第一个公共节点。 使用集合的方法&#xff1a; public ListNode findFirstCommonNodeBySet(ListNode headA,ListNode headB){Set<ListNode> set new HashSet<&g…

Linux服务器部署带Cplex的Java项目

Linux版Cplex安装 Cplex安装包 Cplex 22.1.0 Linux安装包 安装步骤 找到安装包的路径 [roothecs-327697 ~]# cd /www/cplex [roothecs-327697 cplex]# ls cplex_studio2210.linux_x86_64.bin使用chmod 777赋予安装包读、写、执行权限&#xff0c;使用./执行安装 [roothec…

数字IC前端学习笔记:数字乘法器的优化设计(基4布斯编码华莱士树乘法器)

相关阅读 数字IC前端https://blog.csdn.net/weixin_45791458/category_12173698.html?spm1001.2014.3001.5482 使用基2布斯乘法器虽然能减少乘数中0的数量&#xff0c;但最终还是无法减少部分积的数量&#xff0c;因此一种更合理的编码方式产生了——基4布斯编码。它可以将部…

LeetCode刷题---简单组(六)

文章目录 &#x1f352;题目一 69. x 的平方根&#x1f352;解法一&#x1f352;解法二&#x1f352;题目二 70. 爬楼梯&#x1f352;解法一 &#x1f352;题目一 69. x 的平方根 &#x1f352;解法一 class Solution(object):def mySqrt(self, x):""":type x:…

皮肤渲染方法总结

一、皮肤次表面光照 HDRP用的延迟管线&#xff0c;镜面和散射分开进行计算 UE有透射开启和关闭的效果 &#xff08;一&#xff09;镜面反射 BRDF和Kelemen方法 &#xff08;二&#xff09;次表面散射与透射 1.散射&#xff1a;BRDF与BRSSDF&#xff08;从反射点附近的点进行…

基于springboot框架的房屋租赁租房系统

功能如图所示 摘要 房屋租赁租房系统是一个基于Spring Boot框架开发的全新房地产管理平台&#xff0c;它旨在简化租房流程&#xff0c;提供房东和租户之间的高效互动&#xff0c;以满足现代社会对房屋租赁的不断增长的需求。该系统充分利用了Spring Boot的强大特性&#xff0c;…

电源控制系统架构(PCSA)之电源管理软件

下图显示了电源管理软件栈的简化表示。该图说明了OS电源管理框架、具有直接从SCP请求操作功能的组件以及它们与SCP固件之间的关系。 一个重要的方面是&#xff0c;所有硬件电源管理操作都是由SCP代表这些请求者执行的。 这种OS电源管理(OSPM)的简化表示可以分为两部分&#xff…

[NSSRound#6 Team]check(Revenge)

文章目录 考点tarfile文件覆盖漏洞&#xff08;CVE-2007-4559&#xff09;PIN码计算 解题过程非预期解预期解 考点 tarfile文件覆盖漏洞&#xff08;CVE-2007-4559&#xff09; Python 中 tarfile 模块中的extract、extractFile和extractall 函数中的目录遍历漏洞 允许 用户协…

点云配准--对称式ICP

对称式ICP 写在前面的话 针对于局部平面不完美的情况&#xff0c;提出了一种对称式ICP目标函数&#xff0c;相较于传统的ICP方法&#xff0c;增大了收敛域&#xff0c;提高了收敛速度。论文理论说明不甚清楚&#xff0c;实验较少&#xff0c;但代码开源。 理论 对称目标函数…

【Simulink】飞轮储能系统的建模与MATLAB仿真(永磁同步电机作为飞轮驱动电机)

目录 ​1 主要内容 2 结果分析 3 程序链接 ​1 主要内容 该仿真为飞轮储能系统的建模&#xff0c;包括电网侧和电机侧两部分模型&#xff0c;仿真采用永磁同步电机作为飞轮驱动电机&#xff0c;通过矢量控制的方式对其发电和电动的工况进行控制&#xff0c;同时&#xff0c…

数据库访问跳板机

应用场景 在安全性要求高的网络环境&#xff0c;可能会出现数据库ip访问限制&#xff0c;导致数据库只有指定服务器才能访问&#xff0c;在特定业务场景我们可能会经常多人查询该数据库的表&#xff0c;为了解决这个问题&#xff0c;我写了一个小工具。 核心思想 解决方案实…

WindowsTerminal 配置标签页(快速使用PowerCli)

需求 避免每次都需要手动输入密码、手动填写信息才能访问vcenter。结合WindowsTerminal快速创建标签页&#xff0c;需要时一键开启Powercli。 解决 编写启动PowerCli的bat脚本 内容如下 echo off powershell -NoExit -ExecutionPolicy Bypass -Command "Connect-VISe…

NLP之LSTM原理剖析

文章目录 背景simpleRNN的局限性 LSTM手写一下sigmoid例子支持长记忆的神经网络解读3重门 背景 SimpleRNN有一定局限性&#xff0c; 图片上的文字内容: 图片标题提到“SimpleRNN是一种基础模型。它用于解决序列型问题&#xff0c;其中的每一步的输出会影响到下一步的结果。图…

[计算机提升] 查看系统软件

3.1 查看系统软件 此处系统软件为系统安装后自带的一些软件、工具等。包括&#xff1a;管理工具、系统工具、轻松使用工具、附件等。 方法一&#xff1a;通过菜单打开系统软件 1、点击左下角windows菜单键&#xff0c;在弹出的菜单中&#xff0c;任一点击一个字母(示例中为C)&…

听GPT 讲Rust源代码--library/std(10)

题图来自 Rust Development Roadmap[1] File: rust/library/std/src/sys/windows/c.rs 在Rust源代码的rust/library/std/src/sys/windows/c.rs文件中&#xff0c;主要定义了Rust对于Windows操作系统的系统调用接口。该文件定义了各种Windows特定的结构体、枚举和常量&#xff0…

NAS(qnap)中安装git服务(gogs),硬件为TS-453Bmini,固件版本:QTS 5.1.2.2533

NAS(qnap)中安装git服务(gogs)&#xff0c;硬件为TS-453Bmini&#xff0c;固件版本&#xff1a;QTS 5.1.2.2533 1.进入nas的管理界面&#xff0c;找到App Center: 2.在AppCenter中&#xff0c;安装ContainerStation容器工作站&#xff1a; 3.ContainerStation容器工作站中&…

linux驱动开发环境搭建

使用的是parallel 创建的ubuntu 16.04 ubuntu20.04虚拟机 源码准备 # 先查看本机版本 $ uname -r 5.15.0-86-generic# 搜索相关源码 $ sudo apt-cache search linux-source [sudo] password for showme: linux-source - Linux kernel source with Ubuntu patches linux-sourc…

【Kubernetes 基本概念】Kubernetes 的架构和核心概念

目录 一、Kurbernetes1.1 简介1.2 为什么要用K8s?1.3 K8s的特性 二、Kurbernetes集群架构与组件三、Kurbernetes的核心组件3.1 Master组件3.1.1 Kube-apiserver3.1.2 Kube-controller-manager3.1.3 Kube-scheduler 3.2 配置存储中心——etcd3.3 Node组件3.3.1 Kubelet3.3.2 Ku…

qnx resource managers 实例

文章目录 前言一、resource managers 是什么二、device resource managers 实例1. Single-threaded device resource manager2.Multithreaded device resource manager3.Resource Managers that Handle Multiple Devices总结参考资料前言 本文主要介绍如何编写一个 qnx 下 的 …

CSS图片下方4px间距

目录 1&#xff0c;问题表现2&#xff0c;问题解决 1&#xff0c;问题表现 .test-img {height: 100px;outline: 1px solid salmon; }图片下方有4px间距。 图片下方是图片时问题也存在。 2&#xff0c;问题解决 图片设置 display: block;图片设置 vertical-align: middle; …