《实用软件架构:从系统环境到软件部署 》——2.4 架构视图与架构视点

2.4 架构视图与架构视点

以软件架构为论题的书籍、文章、研究项目及相关刊物,都会带有各自的观点。不同的流派对架构有不同的看法,他们会按照各自的看法来做架构,并会将各自的做法加以推广。就本书的主题来说,笔者并不打算专门用一个章节把与软件架构有关的各种观点全都讲解一遍,而是只想展示下面的这种观点,因为笔者觉得它比较务实,而且运用起来较为流畅。

视图和视点

Philippe Kruchten (1995.11)率先开始使用视图(view)与视点(viewpoint)这两个概念,来表达业界对软件架构的各种关注。Kruchten是IEEE 1471标准的一位制定者,该标准明确规定了视图的定义,也引入了视点的概念。Kruchten在论文(参见2.6节)中,是这样来描述这两个概念的:

视点—视点是“一份规范书,用来描述构建视图和使用视图时所应依循的约定。它是一种模式或一份模板,用来确立视图的目标和受众,以及创建视图与分析视图所用的技巧,使得我们可以据此创建出不同的视图。”

视图—视图是“从某个角度对整个系统所做的一种表现,该角度是由一系列彼此相联系的关注点所确立的。”

IBM (n.d.)定义了一套列架构视点,这就是IBM IT
System Viewpoint Library(IBM IT系统视点库)。笔者认为这套架构视点相当完备地涵盖了系统架构的各个方面。如图2-3所示,该视点库中包含4个基本视点和6个正交(cross-cutting)视点。

 

IBM IT System Viewpoint Library中的四个基本视点分别是:

需求(Requirement)—与该视点有关的模型元素,用来捕捉系统中的各种需求,包括业务需求、技术需求、功能需求以及非功能型需求。对于该视点来说,最为常见的捕捉手段是用例与用例模型。

解决方案(Solution)—与该视点有关的模型元素,用来确定一套可以满足相关需求及约束的解决方案。此视点可以细分为两种:

功能视点(Functional)—此视点所关注的模型元素,从本质上来说,都是结构方面的元素,我们不仅要把元素本身实现出来,而且还要把元素之间的(静态和动态)关系建立好,以便用这些元素来构建系统。一般来说,此视点的细节,是通过功能架构来捕捉的,本书第7章将会专门讲解功能架构。

操作视点(Operational)—此视点关注的是怎样用结构元素来构建目标系统,以及怎样把功能视图部署到(由网络、硬件、计算资源、服务器等所构成的)IT环境中。我们通常使用操作模型来捕获此视点的细节,本书第8章将会专门讲解操作模型。

确认(Validation)—通过此视点所建立的模型元素,主要用来评估系统的能力,以确保该系统能够体现出预定的功能,并且能够提供质量合格的服务。我们通常会把功能和非功能方面的测试用例当作验证标准,以判断该系统是否具备预定的能力。

从图2-3中可以看出,这4个基本视点是相互关联的。功能视点与操作视点,可以合起来实现需求视点,并为其提供支持,而这两个视点,又是通过确认视点得以验收的。为了把这张图画得明确一些,笔者并没有专门标出“解决方案”视点,而是直接把构成该视点的功能视点和操作视点画在了图中。

视点库中还有6个正交视点。在图2-3中,4个基本视点周围的那6个同心正方形,就是用来表示这6个视点的。笔者之所以用这样的方式来画图,是想表达这6个正交视点对一个或多个基本视点所造成的影响。

这6个正交视点分别是:

应用(Application)—该视点专注于满足系统所宣称的业务需求。对于该视点来说,应用架构师扮演着主要角色。

技术(Technical)—该视点关注的是硬件、软件、中间件(其定义请参阅第5章)以及打包的应用程序,这些内容合起来可以实现应用程序的功能,并使得应用程序能够运作。对于该视点来说,基础设施架构师和集成架构师扮演着主要角色。

系统管理(Systems Management)—该视点关注部署之后的管理、维护,以及系统的运作。对于该视点来说,应用维护和管理团队扮演着主要角色。

可用性(Availability)—该视点关注怎样才能把系统构建起来,并令其保持可用(比如,怎样才能使系统的正常运行时间达到总运行时间的99.5%),以便满足预先达成的服务级别协议。对于该视点来说,基础设施架构师扮演着主要角色,而应用架构师与中间件架构师,则会为前者的工作提供支持。

性能(Performance)—该视点关注的问题是,怎样令系统的性能可以满足预先达成的服务级别协议(比如,从用户发出请求到系统给出应答,这之间的平均延迟时间要控制在400毫秒以内)。对于该视点来说,应用架构师扮演着主要角色,而中间件架构师和基础设施架构师,则会为前者的工作提供支持。

安全(Security)—该视点关注的是安全方面的系统需求,例如单点登入(single sign-on)、数据传输协议的安全程度,以及防止入侵等。某些安全需求(例如单点登入)主要是由应用架构师来处理的,而确认数据协议(例如HTTPS协议、安全套接字协议)的安全程度以及防止网络入侵等需求,则主要由基础设施架构师来处理。

每一个基本视点和正交视点背后,都隐藏着很多细节。这些视点均各自对应于一套元素,这些元素合起来能够描述出自身的特征及职责。如果理解了这些元素,那我们就能够深入地观察到每个视点的实现方式。尽管隐藏在每个基本视点和正交视点背后的细节有很多,然而笔者此处所要强调的内容,是大家应该意识到它们的存在,并且意识到我们必须从其中的每一个视点或绝大部分视点来对系统的架构进行观察。这种意识很重要。

笔者曾经对很多视点框架做了研究,我感觉其中的绝大多数框架,在基本形式的层面都有着一些共性。之所以会有这种共性,其原因在于:每个框架都想要确立一套相互补充的视角,并且想通过这些视角来观察系统的架构,以便全面地覆盖架构中的各个方面。

我们需要在各种视点框架之间做出选择,或者说,我们至少要从那些特别成熟、特别稳固而且特别持久的视点框架中进行选择。在选择时,大家应该根据自己的需求以及使用视点框架时的舒适程度来进行判断。

时间: 2024-12-21 01:02:49

《实用软件架构:从系统环境到软件部署 》——2.4 架构视图与架构视点的相关文章

《实用软件架构:从系统环境到软件部署 》——第3章 恰到好处地把握架构中的重要方面3.1 软件架构中需要关注的一些方面

第3章 恰到好处地把握架构中的重要方面 你把边界定好,看我怎么在里面大显身手. 第2章强调了一些理由,那些使我们确信:凡是要开发具有一定规模的系统,就必须要重视该系统的软件架构工作.看完该章之后,读者可能会去详细地了解各种架构视图和架构视点,或是去阅读不同的软件架构学派就软件架构中的其他一些方面所写的文章.现在,你可能会想:"架构中最需要关注的是哪些方面呢?我应该从哪里入手呢?面对下一次架构工作,我是否能有充足的准备呢?"能够想到这些问题,那是相当自然的事情. 这是一本注重实效的书,笔

《实用软件架构:从系统环境到软件部署 》——导读

        前言  软件架构这个学科已经有半个世纪的历史了.此概念于20世纪60年代引入,它的灵感来源于建筑物的架构,其中涉及在开始盖楼之前拟定的一些蓝图,这些蓝图描述了建筑师对建筑物的结构所制定的设计方案与规格说明.建筑物的蓝图给出了建筑物在功能方面的设计方案,也就是楼层的空间布局示意图,以及每个建筑工件(例如门.窗.房间.浴室.楼梯等)的尺寸.在使建筑物得以运作的那些方面,蓝图也提供了详细的设计方案,例如承载建筑结构的地基.电线.水管和输气管道的设计,以及下水道系统等,要想使建筑物的功能

《实用软件架构:从系统环境到软件部署 》——2.5 小结

2.5 小结 人类必须首先确信自己所从事的工作是有价值的,然后才能全身心地投入其中,我们必须首先确信自己所做的工作会有成效,然后才有热情去做好这份工作. 笔者在本章中向大家阐述了自己的想法与信念,笔者认为软件架构是有价值的.因为软件架构是否明确,与软件系统能否成功之间是有着一定关系的.于是,笔者就给出了软件架构的定义(软件架构是什么?),并且强调了它的价值(为什么需要做软件架构?) 本章还介绍了架构视图与架构视点这两个概念,并且简要地描述了一套笔者经常会参考的视点库. 第3章将要强调软件架构中的

《实用软件架构:从系统环境到软件部署 》——2.3 为什么需要做软件架构

2.3 为什么需要做软件架构 笔者是这样一种人:除非我能确信自己真的需要去做某件事,并且了解它的重要性和价值,否则,我就很难全身心地投入其中.如果读者也是这样的人,而且你也想了解软件架构的价值到底体现在哪里,那么就请继续往下看吧. 本节将会给出一些理据,来说明软件架构的重要意义.笔者之所以会极其热衷地从事架构工作,正是由于这些理据能够使我感到信服. 2.3.1 把架构视为交流工具 软件架构是一张蓝图,IT系统的设计.构建.部署.维护及管理,都要依照这张蓝图来进行.很多利益相关者都想对系统架构有一

《实用软件架构:从系统环境到软件部署 》——第2章 软件架构是什么?为什么需要做软件架构2.1 背景知识

第2章 软件架构是什么?为什么需要做软件架构 除非我信它,否则不可能全身心地投入其中. 如果你已经读到了这里,那么你应该是真心想要成为一名"务实的软件架构师".我们不能仅仅把这个名号挂在嘴边,而是要在实际的软件与系统开发工作中运用这套理念做出优秀的产品. 软件架构师的做事风格多种多样,而且通常都很有意思.有的架构师喜欢做宏观的思考,喜欢随便拿一张纸画上几笔,或是在白板上画一些方框和线条,而且那些方框看上去好像长得都不太一样.有的架构师不先把宏观的架构情况了解清楚,就急着去研究细节问题.

《实用软件架构:从系统环境到软件部署 》—— 3.2 小结

3.2 小结 做事恰到好处,是一种极其难得的境界,很多行业的工作者都缺乏这种智慧. 笔者在本章只是确定并(非常简短地)描述了架构中的某些方面,它们是软件架构开发工作得以成功的必要和充分条件. 首先我们要从系统环境方面来考虑,把IT系统当成一个黑盒,并且只描绘出这个黑盒与外部的其他应用程序及系统之间的连接和信息交换情况.架构概述可以展示出系统架构中的构建块(ABB),并使架构师可以由此对系统的内部情况有一个初步的了解.功能模型使得架构师可以看到架构的子系统视图,该视图不仅能够对各项功能进行系统化的

《实用软件架构:从系统环境到软件部署 》——2.2 软件架构是什么

2.2 软件架构是什么 系统工程领域中的很多研究团体和个人,都对软件架构给出了自己的解读,他们从不同的视角阐述了怎样才能把软件系统的架构较好地表示出来.这些解读方式或视角,都有其合理的地方,它们本身并没有问题.笔者认为,Bass.Clements和Kazman (2012)给出的解释抓住了软件架构的本质: 程序或计算机系统的软件架构,指的就是系统的结构,该结构由软件组件.外部可见的组件属性,以及它们之间的关系而构成. 那么,这个定义意味着什么呢? 这个定义想要强调的意思,是说软件架构由粗粒度的构

《实用软件架构:从系统环境到软件部署 》——第1章 案例研究1.1 业务问题

第1章 案 例 研 究 我这个人专门解决难题,有什么事尽管拿来问! 生活脱离了环境,就如同船没有了帆.环境使得我们可以专注于手头的工作,它能给人一种方向感,也能给人提供一个理由,使我们觉得完成某件事情是值得的.信息技术(IT)和计算机工程等领域中的架构也是如此,它同样需要有一个存在的理由.我们必须对架构进行实例化,必须按照需要将其实现出来,以解决实际的问题. 笔者将在本章中描述一个虚构的案例,以演示问题的陈述.尽管笔者不会明确宣称它与某个真实案例有所对应,但读者在工作中或许真的就会遇到这么一个类

《实用软件架构:从系统环境到软件部署 》——1.2 小结

1.2 小结 要想把软件开发的各个部分全都维系起来,IT系统的架构可以说是至关重要的一个元素. 在解决当前的问题时,我们经常容易采用过于庞大.过于宽泛的理论来描述它,即便是专业的软件架构师和系统开发者,也有可能会陷入这种状况中.因此,软件架构师在解决问题时,通常应该先缓一步,仔细想一想:我是不是把这个问题解释得太复杂了?我是不是把这个问题推广得过于宽泛了?我是不是对IT系统的架构做了过多的处理? 通过进行案例研究,我们可以为待解决的问题创造一种环境,并为其划定边界,这样做使得我们能够专注于目前所