《架构师》反思:软件架构设计-阿里云开发者社区

开发者社区> 胡庆访> 正文

《架构师》反思:软件架构设计

简介:
+关注继续查看

最近在看《软件架构师教程》,今天就第五章《软件架构设计》总结一下,其中还有自己所联想到的。主要从以下几个方面来描述:

  • 软件架构
  • ABSD
  • 架构模式
  • DSSA
  • 架构评估

 

软件架构

架构的定义,在业界,目前主要分为两类:结构派 和 策略派。结构派认为架构是指软件中各构件的组织结构以及各构件之前的相互关系。策略派认为软件的架构设计是要为软件的每个重要的决择进行权衡,并作出最终决定。

架构,作为系统中最重要的组成部分,对整个系统有着重要的作用:

对于软件开发而言,首先,架构设计能使系统各方面质量达到预期的目标;其次,它能全过程指导开发、测试,并有效地管理软件的复杂性,降低维护成本。

在软件工程方面,架构设计能有效地支持计划的编制,支持冲突分析,使受益人目标一致。

目前对于软件架构的研究,还处于不成熟的阶段。在软件生命周期的各个阶段中,架构设计以及与软件工程的结合,也正处于摸索阶段,正在尝试如何让架构设计更好的指导工程的生命周期各阶段的活动。

 

ABSD

全称:Architecutre Based Software Development,即基于架构的开发方法。就是在架构设计后,以文档化的架构为系统的主线,指导并保证其它活动的顺利开展。

主要经历以下阶段:

image

从图中可以看出,ABSD是一个迭代的开发模型:在需求获取完成之后,需要提取出体系结构的需求,包括功能需求、质量属性及系统的约束,后再者将会成为影响架构设计的重点。架构设计到架构的复审,是一个较小的重复周期,目的是为了架构设计能通过审核达到预期的质量目标。当审核通过后,架构指导开发过程完成系统实现。过程中,可能会对架构进行演化,在一定程度上,也可以说是在做架构的重构,这时,需要再次重复整个过程,这是一个大的迭代。

具体的过程,请看以下几个图:

image image

设计过程完成后,需要对架构进行文档化,主要输入两个文档:《架构规格说明书》、用于测试体系结构需求的《质量设计说明书》

《质量设计说明书》中应该对质量目标进行定义,它也是后面进行架构评估的依据。定义时,可以依据ATAM中的5,具体内容参见本章的“架构评估”小节。

《架构规格说明书》中,应使用较成熟的架构描述方法对架构进行描述。如可采用业界目前比较认可的4+1视图。

文档的完整性是软件架构成功的关键。文档应该从使用者的角度进行编写,必须分发给所有与系统有关的开发人员、且必须保证开发者手上的文档是最新的。同时,这些输出的文档也应该面向架构评估。

复审之前,最好做一个较小的系统原型,以方便评估。

复审的目前是为了保证架构能满足软件的质量要求,架构设计的构件和层次要比较合理,架构的描述要清晰。

image image

 

架构风络

其实,架构风格就是架构模式。

模式,是在一定的环境下,不断地重复出现的一种形式。也就是说,一个特定的架构模式,有其适用的使用场景。例如,最受欢迎的三层架构,在系统较小时就不太适用。又如,面向对象的架构,在对于以数据处理为核心的应用场景也可能不太适用,同时,对于查询密集的系统使用面向对象,极大影响系统性能,反倒成为一种反模式。

架构重用,是软件架构研究的核心目标之一。对架构模式的研究,可以极大的促进业界对软件架构的重用。

 

DSSA

由于一个领域中的核心领域对象往往不会发生改变,所以对它们进行研究,可以实现核心业务的积累和重用。由于整个领域中核心对象往往不会发生改变,而围绕它们的应用,按照应用程序的类别划分后,同一类别下的应用程序往往架构也是类似的。所以对一类系统进行架构分析,就是为了找出在此类系统中通用的架构模式。

GIX4项目也是使用了基于领域的架构。准确地说,GIX4的架构是使用了领域驱动、模型驱动的产品线架构。具体架构内容,会在后面的文章《架构设计师-GIX4-架构介绍》中介绍,其中会对DSSA如何在GIX4上应用做一个较全面的讲述。

 

架构评估

在架构设计的目的中,我已经说过,架构设计最重要的目的是为了让系统能满足预期的质量需求。所以,在架构评估阶段,最重要的也就是评估这个架构是否能满足质量需求。也就是说,架构评估,重点关注的是质量属性。

在《教程》中提到,本阶段需要使用场景的方式来定义产品的质量目标。其实不然,质量目标是架构设计的重要依据,往往是在架构设计的初始阶段就已经被定义好了,也就是前面提到的架构设计阶段的输出《质量设计说明书》。虽然那时的定义不一定完整,但是一样可以在架构评估过程中,先对它进行评估,然后就可以作为架构评估过程中质量评估的基准了。

其实,就大方向上看,架构评估也是架构设计的一个部分。评估的过程,就是各专家在一起对架构初稿进行审核、提问、反思、建议。架构师以一人之力,很难把一个大型系统的架构设计得天衣无缝;这时集多人的力量在一起对初稿进行评估,可以起到查漏补缺的作用。

 

小结

架构设计是软件设计过程中最重要的活动之一,架构设计的优劣直接影响到目标系统的各个质量属性。

我认为,基于架构的开发方法,是一个很重要的方法论,我们可以用它来保证软件达到质量标准,并指导整个开发过程。同时,可以结合目前业界流行的敏捷方法来实施,这样可以在不同高度对软件开发进行控制。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
10061 0
歪理邪说解析架构设计师上午考试试题之一(分析2010下半年系统架构设计师上午试题01-05题)
歪理邪说解析架构设计师上午考试试题之一 分析2010下半年系统架构设计师上午试题01-05题 【引言】 1.一直期待专业的技术话题也能和《明朝哪些事》一样,有趣和好玩,能吸引大家的去阅读,并享受其乐趣; 2.培养对技术的兴趣,有时候比掌握技术本身更重要;一旦有了浓厚的兴趣,自己主动就会主动去探寻,去发现技术的秘密。
796 0
[软考考点解析]软件设计师--系统可靠度
1.题目 某系统由下图所示冗余部件构成,若每个部件千小时可靠度为R,则该系统的千小时可靠度为:
10 0
支付宝全局架构师曹刚:为12亿用户设计架构是什么体验?
支付宝全局架构师曹刚:为12亿用户设计架构是什么体验?
398 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
13875 0
[软考考点解析]软件设计师--主存与Cache地址映射方式
1. 题目 主存与Cache的地址映射方式中,____方式可以实现任意主存的任意一块装入Cache中任意位置,只有装满才需要替换。 A 全相联 B 直接映射 C 组相联 D 串并联
8 0
歪理邪说解析架构设计师上午考试试题之八(分析2010下半年系统架构设计师上午试题36-40题)
歪理邪说解析架构设计师上午考试试题之八 分析2010下半年系统架构设计师上午试题36-40题 【引言】 1.一直期待专业的技术话题也能和《明朝哪些事》一样,有趣和好玩,能吸引大家的去阅读,并享受其乐趣; 2.培养对技术的兴趣,有时候比掌握技术本身更重要;一旦有了浓厚的兴趣,自己主动就会主动去探寻,去发现技术的秘密。
816 0
[软考考点解析]软件设计师--校验码纠错
1.题目 已知数据信息为16位,最少应附加____位校验位,才能实现海明码纠错。 A 3 B 4 C 5 D 6
4 0
通向架构师的道路(第六天)之漫谈基于数据库的权限系统的设计
一、权限系统 这一天将讲述一个基本的基于数据库的权限管理系统的设计,在这一天的课程的最后将讲述“左右值无限分类实现算法”如何来优化“系统菜单”的结构而告终。
999 0
+关注
胡庆访
Rafy 框架作者。(https://github.com/zgynhqf/rafy) 专注于:领域驱动设计、面向服务架构、插件化架构、模型驱动架构、产品线工程、快速界面生成。
247
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载