《软件架构设计文档》模板.doc
《《软件架构设计文档》模板.doc》由会员分享,可在线阅读,更多相关《《软件架构设计文档》模板.doc(17页珍藏版)》请在咨信网上搜索。
1、 Version: Software Architecture Document Date: 目 录1.文档简介41.1文档目的41.2文档范围41.3定义、缩写词和缩略语41.4参考资料42.架构描述方式42.1架构视图阅读指南42.2图表与模型阅读指南53.架构设计目标53.1关键功能53.2关键质量属性53.3业务需求和约束因素64.架构设计原则64.1架构设计原则64.2备选架构设计方案及被否原因64.3架构设计对后续工作的限制(详设,部署等)65.逻辑架构视图75.1职责划分与职责确定75.2接口设计与协作机制85.3重要设计包106.开发架构视图116.1Project划分116.
2、2Project 1116.2.1Project目录结构指导126.2.2程序单元组织126.2.3框架与应用之间的关系(可选)126.3Project 2136.4Project n137.运行架构视图137.1控制流组织137.2控制流的创建、销毁、通信147.3加锁设计148.物理架构视图148.1物理拓扑148.2软件到硬件的映射158.3优化部署169.数据架构视图169.1持久化机制的选择179.2持久化存储方案179.3数据同步与复制策略1710.关键质量属性的设计原理17 1. 文档简介帮助读者对本文档建立基本印象,并为阅读后续内容扫清障碍。1.1 文档目的文档目的,非项目目的
3、。否则造成同一项目多个文档之间的内容重复,不利于文档维护。本小节应指明文档针对的读者对象,最好列出各种读者角色,并说明每种读者角色应该重点阅读的章节。1.2 文档范围文档的Scope,非项目的Scope。否则造成同一项目多个文档之间的内容重复,不利于文档维护。1.3 定义、缩写词和缩略语集中列举文档中的定义、缩写词和缩略语。1.4 参考资料本项目经审核的计划书、合同、上级批文;本项目的其他已发表文件;本文档引用的文件资料,如软件开发标准。具体而言,应包括参考资料的题目(必须)、编号、版本号(必须)、发表日期、发布方,必要时还可以说明如何使用这些资料。2. 架构描述方式 为了让读者更好地理解架构
4、文档,在本节应当说明文档涉及的架构视图,并指明为了描述设计决策用到了哪些图表和模型。2.1 架构视图阅读指南以多视图的方式来组织架构文档是大势所趋。ADMEMS推荐的是经过优化的5视图方法,如下图所示。2.2 图表与模型阅读指南对后续文档内容中所用到的建模语言(例如UML)、表格(例如目标-场景-决策表)等进行说明。3. 架构设计目标功能、质量、约束,一个都不能少。3.1 关键功能对架构设计至关重要的功能,包括如下4类:核心功能、必做功能、高风险功能、独特功能。所谓独特功能,指这个功能覆盖了上述3类功能没有涉及到的职责。3.2 关键质量属性人之所以痛苦,很多时候是因为追求错误的东西。下图是AD
5、MEMS方法确定关键质量的5大原则的整体思路图。3.3 业务需求和约束因素ADMEMS方法创造性地提出约束需求的4大类型,这是一种极为实用的分类方式。特别是业务需求对架构设计而言是一种约束的观点,解决了很多架构师的现实困惑。下图标明了4类约束在“需求层次-需求方面矩阵(又称ADMEMS矩阵)”中的位置,可以帮助我们理解产生约束需求的根源。4. 架构设计原则投标时经常讲“架构设计原则”,但到了架构文档,这些着眼大局的考虑却“丢了”。ADMEMS方法推荐的本文档模板,认为应当把它们“找回来”。4.1 架构设计原则着重描述重大的权衡取舍考虑。4.2 备选架构设计方案及被否原因在概念架构一级,对备选架
6、构设计方案进行描述,并阐述它们未被采用的原因。这有利于团队了解当前架构设计方案的来龙去脉,提高团队对当前架构设计方案的认可度。4.3 架构设计对后续工作的限制(详设,部署等)架构设计不仅应该包含“指导”,也应该包含重要的“限制”。例如,一份只是说明“性能和可扩展性都重要”的架构文档,实际上忽视了“可扩展性和性能之间存在的矛盾关系”。此时,最有效的办法就是在架构文档中明确说明“任何提升可扩展性的架构设计和详细设计,都应通过架构团队的评审才能引入,以确保性能目标不受重大影响”。5. 逻辑架构视图 关注点:此架构设计视图的关注点是职责划分。注意:逻辑架构视图无疑是最重要的,但同时也应避免“架构 =
7、模块 + 接口”等以偏概全的认识。参考:任何复杂系统的架构设计都不是一蹴而就的,所以架构师需要理性思维过程的指导。针对逻辑架构设计这个关键环节,一线架构师实践指南一书给出了2条建议:一是“以质疑驱动的螺旋思维”,二是相对分离地考虑“结构方面的切分”和“行为方面的定义”。下图所示即为ADMEMS方法推荐的逻辑架构设计理性思维过程。 5.1 职责划分与职责确定内容:将系统切分成更小的单元,并明确这些单元的职责。具体而言,职责单元可以是层、子系统、模块、关键类等。意义:一句话,职责划分不合理,功能和质量都会受到影响。也就是说,功能需求和质量需求无一不和职责划分相关:一方面,每个功能都是由一条职责协作
8、链完成的;另一方面,职责划分方式也影响着质量,于是需要职责模型针对特定质量属性要求做出相应调整和优化。很多人认为架构设计就是职责划分的艺术,虽略显片面,但足以表明职责划分的重要性。参考:基于对业界大量案例的研究,ADMEMS方法梳理出了“模块划分的3种必用手段”,如下图所示,更多内容可参考一线架构师实践指南一书。 5.2 接口设计与协作机制内容:本节描述接口的定义,以及协作的方式和规范。意义:恰恰是因为有了各模块之间“未来合作的契约”,分头开发各模块才有了基本保证。参考:ADMEMS方法推荐利用“包-接口”图,来识别接口。下图为一个“包-接口”图的示例。 参考:ADMEMS方法推荐使用序列图,
9、建议少用、甚至杜绝使用协作图。下图为一个序列图的示例。 5.3 重要设计包内容:对重要子系统的设计进行“灰盒”级描述。意义:“每个子系统在架构设计中都应保持黑盒子”的观点,过于理想化了。对于业务层、通用协作机制而言,经常需要在架构设计期间就引入“灰盒”级描述。参考:类图和灰盒包图,在本节中较多出现。下图为一灰盒包图示例。 6. 开发架构视图关注点:此架构设计视图的关注点是程序单元组织。注意:此架构设计视图是必须的、不应“剪裁”掉的。但实际情况却是,很多架构师不关注开发架构视图,导致很多程序开发人员抱怨“架构师就知道高来高去,架构对编程工作没什么指导性”。6.1 Project划分内容:本节说明
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件架构设计文档 软件 架构 设计 文档 模板
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【精****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【精****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。