软件体系结构复习笔记
Cha1
1软件架构概念:
2 是系统的一个或多个结构,它们由软件组件,组件的外部可见属性以及组件之间的关系组成。
3 组件的外部可见属性是指其他组件对该组件所做的假设。
4软件架构的多个结构:
5 静态的角度:
6 模块结构
7 分析类结构
8 类结构
9 动态的角度:
10 进程结构
11 数据流
12 控制流
13 使用结构
14 调用结构
15 层次结构
16 部署的角度:
17 物理结构
18
19架构不止是功能需求的结果
20
21Ch2:
22需求包含三要素:功能,质量,限制条件
23质量属性:系统在其生命周期过程中所表现出来的各种特征
24质量属性的关系:
25 一个质量属性的获取对其他质量属性可能产生正面或者负面的影响。
26 任何质量属性都不可能在不考虑其他属性情况下单独获取。
27质量属性举例:
28 运行时可见属性:性能,可用性,安全性
29 维护时可见属性:可修改,可扩展,可移植
30 易用性:
31 可学习性
32 可记忆性
33 错误避免
34 错误处理
35 满意度
36
37质量场景创建的参与人员:
38 最终用户
39 系统管理员
40 维护人员
41 客户
42 开发组织
43构架本身的质量属性:
44 一致性
45 正确性和完整性
46 可构建性
47生成质量属性场景的目的和意义:
48 帮助构架师生成有意义的质量属性需求
49 使质量属性需求的描述规范化
50 某一场景是一类场景的代表,系统将以完全相同的方式做出反应。
51构架的商业属性(限制):
52 上市时间
53 成本和收益
54 预期系统生命周期长短
55 目标市场
56 推出计划
57 与老系统的集成
58
59第三章:
60软件架构样式的种类:
61 以数据为中心
62 数据流
63 虚拟机
64 调用-返回
65 独立组件
66 C/S
67构架的异质性:
68 局部异质
69 层次异质
70 并行异质
71
72ISO/OSI七层参考模型:
73 应用层
74 表示层
75 会话层
76 传输层
77 网络层
78 数据链路层
79 物理层
80
81软件框架:
82 提取特定领域软件的共性部分形成的体系结构。
83框架和架构的关系:
84 框架不是构架。
85 构架确定了系统整体结构、层次划分、不同部分之间的协作等设计老驴。
86 框架比构架更具体,更偏重于技术。
87 一个框架对应一个架构,一个架构可以有多个框架。
88
89第四章:
90架构战术:影响质量属性的设计决策。
91架构策略:架构中所采用的战术的集合。
92可用性的战术:
93 错误检测的战术:
94 回声
95 心跳
96 异常
97 错误恢复的战术:
98 表决
99 主动冗余
100 被动冗余
101 备件
102 状态再同步
103 检查点/回滚
104 错误预防的战术:
105 进程监视器
106 从服务中删除
107 事物
108可修改性的战术:
109 局部化修改的战术:
110 维持语义一致性
111 预期期望的变更
112 泛化模块
113 限制可能的选择
114 防止连锁反应的战术:
115 信息隐藏
116 维持现有的接口
117 添加结构
118 添加适配器
119 提供一个占位程序
120 推迟绑定时间的战术:
121 运行时注册
122 配置文件
123 多态
124 组件更换
125 遵守已定义的协议
126实施性能的战术:
127 影响响应时间的两个基本因素:
128 资源消耗
129 阻塞时间:
130 资源争用
131 资源的可用性
132 对其他计算的依赖性
133 控制对资源需求的战术:
134 减少处理一个事件所需要的资源:
135 提高计算效率
136 减少计算开销
137 减少需要同时处理:
138 管理事件率
139 控制采样频率
140 控制系统的使用:
141 限制执行时间
142 限制队列的大小
143 资源管理的战术:
144 引入并发
145 维持数据或计算的多个副本
146 增加可用资源
147 资源仲裁常见的调度策略:
148 先进/先出
149 固定优先级:语义重要性;时限时间单调;速率单调
150 动态优先级调度:轮转;时限时间最早优先
151 静态调度
152实施安全性的战术:
153 用于抵抗攻击的战术:
154 对用户进行身份验证
155 对用户进行授权
156 维护数据的机密性
157 维护完整性
158 限制暴露的信息
159 限制访问
160 检测攻击的战术:
161 从攻击中恢复的战术:
162 回复状态
163 识别攻击者
164易用性的战术:
165 运行时战术:
166 维持任务的一个模型
167 维护用户的一个模型
168 维护系统的一个模型
169 设计时战术:
170软件架构样式与战术的关系:
171 软件架构样式是从战略层面解决质量问题,战术是从具体部署上给猪解决质量问题的局部策略。
172
173
174第五章:设计构架
175基于构架的开发步骤:
176 为软件系统创建一个商业案例
177 弄清系统需求
178 构建构架
179 正确表述此构架,并与有关各方进行交流
180 对此构架进行分析和评价
181 实现基于构架的系统并保证与构架相一致
182 系统维护时,构架文档应同步维护
183构架驱动的因素:
184 功能
185 质量
186 部分限制条件(限制条件的某个子集)
187
188良好架构的评判原则(判断题常考):
189 设计构架过程的建议:
190 架的设计应该由一门设计师来完成
191 设计师应该全面掌握对系统的技术需求,以及对各项定性指标的优先级清单。
192 构架的文档完备,并蚕蛹所有人员认可的文档形式。
193 构架设计文档应让各风险承担者积极评估。
194 通过对构架分析,得出明确的定性与定量指标。
195 构架设计应该有助于具体实现。
196 允许构架带来一定的资源争用,并给出可行的解决方案。
197 关于构架的结构的建议:
198 构架由定义良好的模块组成,各个模块的功能划分应该基于信息隐藏。
199 模块的划分应体现出相互独立的原则。
200 把计算机基础结构的特性封装在一定的模块
201 构架尽量不依赖某个特定版本的商品产品或工具。
202 产生数据的功能和使用数据的功能应分属于不同的模块。
203 对并发系统,构架应充分考虑进程与模块结构的不对应。
204 进程编写要考虑到与特定处理器的关系,并容易改变关系。
205 构架应尽量采用一些已知的设计模式。
206
207ADD构架设计的步骤:
208 样本输入
209 选择要分解的模块
210 根据下列5个步骤对模块进行求精(重点):
211 从具体的质量场景和功能需求集合中选择构架驱动因素。
212 选择满足构架驱动因素的构架模式。
213 实例化模块并根据用例分配功能,使用多个视图进行表示
214 定义子模块的接口
215 验证用例和质量场景并对其进行求精,使它们称为子模块的限制。
216 对需求进一步分解的每个模块重复上述步骤。
217创建骨架系统:
218 思想:提供一种基本能力,以一种对项目有利的顺序实现系统的功能。
219 好处:
220 提高开发效率,鼓舞士气。
221 能更早发现复杂的依赖关系。
222 使开发人员更多关注最难实现的部分。
223 能够缩短系统集成时间,降低其成本,并使集成成本更明确。
224 便于评审和测试。
225 步骤:
226 实现处理构架组件交互的软件部分
227 选择组件逐步添加到系统中。
228 逐步进行测试。
229架构师的职责:
230 了解所在组织的业务目标,使架构更好地支持业务目标。
231 规划产品的开发与严禁
232 规划和建设架构级的重用etc
233
234
235分析软件构架的原因(重要):
236 它是风险承担者之间的交流平台,是早期设计决策的体现,是可传递的模型。
237 软件质量不可能在软件开发的最后阶段追加上去,必须在设计之初就考虑到。
238
239第七章:
240构架评审:
241 成本:
242 人员时间成本
243 构架评审部门的组织开销
244 构架评审部分要求高级设计人员参与的代价(不就是人员时间成本吗。。。
245 收益:
246 及早发现构架中存在的问题
247 构架的改进
248 财务收益
249 强制位评审做准备
250 捕获构架设计的基本思想
251 验证需求的有效性
252评审实施:
253 按问题的重要性进行分类
254 强调那些与偶家相符或相悖的重要问题
255 必须记载评审中所提的每个问题
256构架评审的主要指导原则:
257 把由独立部门实施的正规的构架评审作为项目开发周期规划的一部分。
258 选择评审的最佳时间,尽早预审一次。
259 选择恰当的评审技巧
260 签署评审合同
261 限制所要品神的质量属性的个数
262 要保证评审小组中有构架方面的专家,领域专家,资料员,后勤员。
263 一定要有系统设计师。
264 收集各种场景数据,并在此基础上形成评审清单。
265
266第八章:
267架构权衡分析法(ATAM):
268 特点:不仅可以揭示出构架满足特定质量目标的情况,而且可以让我们更清楚地认识质量目标之间的联系。
269 输入:用场景集合捕获的质量要求。
270 输出:
271 简介的框架表述
272 表述清楚的业务目标
273 构架决策到质量需求的映射
274 所确定的敏感点和权衡点集合
275 有风险决策和无风险决策
276 风险主题的集合
277 阶段:
278 评估小组和项目决策者共同决定评估细节
279 评估小组收集信息和分析
280 风险承担着参与评估
281 评估小组自我检查和改进,提交书面报告
282 步骤(重点):
283 ATAM方法的表述
284 商业动机的表述
285 构架的表述
286 对构架方法进行分类
287 生成质量属性效用树
288 分析构架方法
289 集体讨论并确定场景优先级
290 再次分析构架方法
291 结果的表述
292
293第九章:
294 文档:
295 目的与作用:让不同的风险承担者都能快速找到和理解他们需要的信息。
296 基本原则:从读者的角度出发。