- 1、本文档共18页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Software Architecture DocumentVersion 1.0Revision HistoryDateVersionDescriptionAuthor yyyy-mm-dd x.xdetailsname文档简介[帮助读者对本文档建立基本印象,并为阅读后续内容扫清障碍。]文档目的[文档目的,非项目目的。否则造成同一项目多个文档之间的内容重复,不利于文档维护。本小节应指明文档针对的读者对象,最好列出各种读者角色,并说明每种读者角色应该重点阅读的章节。]文档范围[文档的Scope,非项目的Scope。否则造成同一项目多个文档之间的内容重复,不利于文档维护。]定义、缩写词和缩略语[集中列举文档中的定义、缩写词和缩略语。]参考资料[本项目经审核的计划书、合同、上级批文;本项目的其他已发表文件;本文档引用的文件资料,如软件开发标准。具体而言,应包括参考资料的题目(必须)、编号、版本号(必须)、发表日期、发布方,必要时还可以说明如何使用这些资料。]架构描述方式[为了让读者更好地理解《架构文档》,在本节应当说明文档涉及的架构视图,并指明为了描述设计决策用到了哪些图表和模型。]架构视图阅读指南[以多视图的方式来组织《架构文档》是大势所趋。ADMEMS推荐的是经过优化的5视图方法,如下图所示。]图表与模型阅读指南[对后续文档内容中所用到的建模语言(例如UML)、表格(例如目标-场景-决策表)等进行说明。]架构设计目标[功能、质量、约束,一个都不能少。]关键功能[对架构设计至关重要的功能,包括如下4类:核心功能、必做功能、高风险功能、独特功能。所谓独特功能,指这个功能覆盖了上述3类功能没有涉及到的职责。]关键质量属性[人之所以痛苦,很多时候是因为追求错误的东西。下图是ADMEMS方法确定关键质量的5大原则的整体思路图。]业务需求和约束因素[ADMEMS方法创造性地提出约束需求的4大类型,这是一种极为实用的分类方式。特别是业务需求对架构设计而言是一种约束的观点,解决了很多架构师的现实困惑。下图标明了4类约束在“需求层次-需求方面矩阵(又称ADMEMS矩阵)”中的位置,可以帮助我们理解产生约束需求的根源。]架构设计原则[投标时经常讲“架构设计原则”,但到了《架构文档》,这些着眼大局的考虑却“丢了”。ADMEMS方法推荐的本文档模板,认为应当把它们“找回来”。]架构设计原则[着重描述重大的权衡取舍考虑。]备选架构设计方案及被否原因[在概念架构一级,对备选架构设计方案进行描述,并阐述它们未被采用的原因。这有利于团队了解当前架构设计方案的来龙去脉,提高团队对当前架构设计方案的认可度。]架构设计对后续工作的限制(详设,部署等)[架构设计不仅应该包含“指导”,也应该包含重要的“限制”。例如,一份只是说明“性能和可扩展性都重要”的《架构文档》,实际上忽视了“可扩展性和性能之间存在的矛盾关系”。此时,最有效的办法就是在《架构文档》中明确说明“任何提升可扩展性的架构设计和详细设计,都应通过架构团队的评审才能引入,以确保性能目标不受重大影响”。]逻辑架构视图[关注点:此架构设计视图的关注点是职责划分。][注意:逻辑架构视图无疑是最重要的,但同时也应避免“架构 = 模块 + 接口”等以偏概全的认识。][参考:任何复杂系统的架构设计都不是一蹴而就的,所以架构师需要理性思维过程的指导。针对逻辑架构设计这个关键环节,《一线架构师实践指南》一书给出了2条建议:一是“以质疑驱动的螺旋思维”,二是相对分离地考虑“结构方面的切分”和“行为方面的定义”。下图所示即为ADMEMS方法推荐的逻辑架构设计理性思维过程。]职责划分与职责确定[内容:将系统切分成更小的单元,并明确这些单元的职责。具体而言,职责单元可以是层、子系统、模块、关键类等。][意义:一句话,职责划分不合理,功能和质量都会受到影响。也就是说,功能需求和质量需求无一不和职责划分相关:一方面,每个功能都是由一条职责协作链完成的;另一方面,职责划分方式也影响着质量,于是需要职责模型针对特定质量属性要求做出相应调整和优化。很多人认为架构设计就是职责划分的艺术,虽略显片面,但足以表明职责划分的重要性。][参考:基于对业界大量案例的研究,ADMEMS方法梳理出了“模块划分的3种必用手段”,如下图所示,更多内容可参考《一线架构师实践指南》一书。]接口设计与协作机制[内容:本节描述接口的定义,以及协作的方式和规范。][意义:恰恰是因为有了各模块之间“未来合作的契约”,分头开发各模块才有了基本保证。][参考:ADMEMS方法推荐利用“包-接口”图,来识别接口。下图为一个“包-接口”图的示例。][参考:ADMEMS方法推荐使用序列图,建议少用、甚至杜绝使用协作图。下图为一个序列图的示例。]重要设计包[内容:对重要子系统的设计进
文档评论(0)