SCMLife.com

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 5239|回复: 1

[推荐] 利用RSA定义应用程序架构,第 1 部分: 构想架构

[复制链接]
发表于 2012-4-23 12:11:39 | 显示全部楼层 |阅读模式
本帖最后由 技术狂人 于 2012-4-23 13:38 编辑 & d" d* v! v2 r9 t9 B

5 |+ \6 m1 H0 t: x" S: E9 q+ {6 e简介5 \) o5 C0 T: k5 p6 H% h& x* h
有许多种方法都可以提供可定制的最佳实践,帮助企业可靠地提供优质软件。敏捷软件开发是目前的主流,其核心原则之一是采用迭代和增量的方法。本文从一个软件架构师的角度出发,重点介绍一些具体活动,并假定读者精通敏捷实践和迭代开发(有关 IBM agility@scale、IBM Practices、OpenUP 和 Rational Unified Process 的更多信息,请参阅 参考资料 部分)。7 Y" y  I: V: q" q- l
本文的主要目的是说明 Rational Software Architect 8(以下简称 RSA)如何有助于架构性思考和记录。RSA 是一个协作式设计平台,可以提供高品质的架构。RSA 帮助您在不同抽象的层次定义模型,在软件工程中可以利用它来支持行业最佳实践。
8 h+ g! n0 u6 S, K% h% l0 F: K/ Q3 g
0 d+ o- q+ Z3 J' Z# e/ M# [& K1 V

% @% {2 F( B$ C: F+ G) ?+ M0 _架构分析:构想和发展架构
, v: f+ ~  W4 g* }: B( L" d架构分析是一组活动,可以构建和完善系统的软件架构。如果反复进行架构分析,这种思考有助于发现和解决在软件开发过程中的问题,无需大量前期的架构工作。架构分析活动对每一个软件密集型系统都很重要。不管教条式的敏捷开发教导员可能会说什么,没有架构分析,就不可能有成功的软件开发。# A; a4 y/ u. I+ U$ i
架构分析发生在两个不同的地方。首先,在项目的开始,它通常被称为迭代 0,或冲刺 0。在此初始迭代过程中,软件架构师希望根据大量已知的需求限制、架构限制、决策和目标来构想架构。架构构想并不是一个漫长而繁琐的活动。根据系统的复杂性,通过有限时间的迭代,完成此构想可能只需要几天甚至几个小时的时间。
, `, w7 R& ^/ Z作为一个软件架构师,您通常需要按照以下步骤来勾勒出您的软件密集型系统的目标架构:% n# [9 |" q  B0 K
  • 确定重要的需求:对架构产生重大影响的关键功能性和非功能性需求
  • 确定候选架构:基于架构限制和目标的系统高层架构
  • 定义初始部署模型:表示表该系统的部署节点的拓扑
  • 定义域模型:关键业务实体和它们之间的关系。
    ! |% b. }% A$ J- p  x, W! I
可用的电子书从作者的博客文章下载电子书 "Evolutionary architecture with Rational Software Architect v8"。
# W- p' ~! f, W$ E6 Z6 ^& A3 H! b. I) U+ Y# g# c
一旦您已经完成初始技术愿景,您就可以在健全的架构基础上构建您的系统。在每次迭代中,开发团队都会发现新的技术挑战和新的改进机会。那些扮演软件架构师角色的专业人员需要作出新的架构决策。这就是持续架构改进是软件密集型系统开发的关键的原因。架构不是那种预先创建、然后撇下不管的东西。架构思考是软件开发的一部分,贯穿项目的始终。
0 i$ |! Z$ L# E1 D% K% b. M3 I' L以下架构活动通常在开发迭代过程中执行:. B7 T/ U: X5 q* Z9 @& P5 j0 l
  • 优化架构机制:可以满足在第一步中确定的架构性重要需求的技术概念。
  • 优化设计元素:架构性重要设计元素
  • 优化部署架构:部署单元和拓扑' d; t, _/ H! K0 w# U) J6 D
迭代活动将在本系列的第 2 部分中介绍。
5 n+ r& y. a2 D
: Z& Y* j: U( J, Z: T图 1. 迭代和增量架构分析: N& V2 u% c  T$ s

1 V* _& R& _  E" R, g! b  d7 h' r. C$ E  @4 }# V5 p
虽然本文不包括审查活动,但任何有经验的从业人员都知道,必须定期验证架构,以验证它与团队的要求和需求是一致的。所以,您需要一个有效的机制来捕获架构,并与不同的利益相关者就架构进行沟通。) n7 v" z, ]& E* @) \1 ~


/ i3 K. O# m6 G2 }+ L( Y
( P' d7 `" z; }0 C# @$ M使用视图描述架构: B$ ^$ H& D* w
用于描述架构的一个成熟的、被广泛采用的方法是,使用了视图和视角。视图是从一组关注或兴趣的视角对整个系统的表示。从利益相关者的视角来看,视图解决系统的所有关键或重要的方面。由于一个系统通常有多个利益相关者,需要若干个视图来概括所有利益相关者的关注事项。
0 m# u+ T" L1 q, @在 1995 年,Philippe Kruchten 提出了一个用于描述软件密集型系统架构的模型:软件架构的 4 +1 视图模型(有关详细信息,请参阅 参考资料)。在“4+1”模式中的大部分概念已包含在开发流程中,如 IBM Rational Unified Process (RUP) 或 OpenUP。最近,IEEE 1471 标准化了视图的定义,以解决一个软件体系结构的多个利益相关者的关注事项(请参见 参考资料 部分,了解有关 IEEE 1471-2000 / ISO 42010 的更多信息)。# N" f8 ~. }% z' k
在原始“4+1”模型中,使用了五个视图提供系统的全面描述,如图 2 所示。
$ ~& D9 p* q: y2 J1 y+ D% }8 k. S5 |, J, ?
图 2. 4+1 架构视图模型
; t/ @4 n# C6 U- P3 j3 D$ B% [3 q
2 r; X7 p* I9 U8 Y
; W4 M! V/ D. Y* H6 ^在“4+1”模型中,每个视图解决一组特定的利益相关者的关注事项,让各利益相关者都能从软件架构中找到他们所需的东西。该模型是可定制的。根据项目的复杂性,您可能只需要建议视图的一个子集。该模型也是可扩展的,所以您可能希望添加其他视图,从不同的视角来形容你的架构。请注意,通常可以将额外的视图折叠成现有视图的子类别。
7 a1 t) @3 @$ M6 T- j# Q; x在表 1 中,每行代表一个视图及其相应的受众、领域和模型。
" Y9 W+ o( v. d3 P) v8 X1 S+ n2 x! e  c( I
表 1. 架构视图4 }5 u8 x+ f1 {1 e0 l9 P8 J
视图受众领域模型
逻辑设计人员用例实现分析模型
" y  I& X# s& o. C7 A/ ~& Q6 L. |设计模型
流程集成商性能  r5 _" d8 E! U  t! ~1 u. _. o
可扩展性6 l! N/ M! X9 x' W+ n5 f' ~$ Y
并发
部署模型
# V$ g9 ~/ k% H, H4 d& a设计模型
实施程序员软件组件实施模型
部署部署经理物理节点部署模型
场景所有人功能性需求用例模型( d, q5 ?: Q. i3 m/ A
用户故事' ?" b% e- o6 O! M
业务流程
数据$ w6 {2 N3 L. q& [' ^
(可选,或作为逻辑视图的一部分)
数据专家" t) |& Q7 C4 x' i: f- L
数据管理员
数据持久性数据模型
* I% x$ N) A7 u! m  w1 b# ]# B
注:/ ^: D' d/ p2 E4 d. @3 s8 J% U
传统上,流程视图对于应用程序并不是很重要,因为平台在本地处理线程。然而,您可以部署模型中选择记录一些并发问题,也可以在设计模型中记录一些通讯机制(同步和异步)。4 s  Y) a% D' Q/ f! i! K% Z4 i


! p) A$ c9 `$ |4 A3 G2 \9 f
/ ~2 A1 p( d! v$ X准备工作区
# O- P' X! s& a  _8 p在启动 RSA 之前,请确保您已经安装了一套最基本的工具,以支持架构师工作。使用 Installation Manager 验证已选中 “Architect – Standard(架构师 - 标准)” 选项,如图 3 所示。预定义的配置文件支持 UML 和拓扑建模功能,您执行本文中提出的各项任务时需要这些功能。
. m  {' T2 e+ M: m$ F$ _0 N. p2 n) l& x! A/ R
图 3. 标准架构师配置文件
& s6 U" k3 n. u/ g2 \ 0 S4 I# F# |+ z7 `5 ?- d
' `% i( Q& v. ~
下一步是创建一个新的工作区。要做到这一点,需要启动 RSA 并指定一个存储目录(图 4)。
5 x, _* M2 U& U; x/ S% b& W" y1 p. C4 ]: b. ^- _- v1 d* @
图 4. Workspcae Launcher 窗口
  v9 I8 W% |8 p) e" K
* ?$ x; w6 X* s' M  u1 t- f' x0 \# `$ B& I) _7 p: M
RSA 提供了许多不同的透视图来定义 Workbench 窗口中视图的初始设置和布局。在进行下一项工作之前,请确认 Modeling 透视图已打开(图 5)。
% U) J2 |7 Z' w% O+ `2 q! f+ l8 ]
图 5. Open Perspective 窗口; l2 z, K& J( y7 h

/ }2 X/ y9 ^% E7 d- _; y: s1 z* Q9 u  z$ _- b, r( K: N' W
RSA 带有不同的预定义 UML 模型模板。在 Modeling Perspective 中,您可以根据需要添加任意数量的模型,以记录您的系统架构(图 6)。
; {2 [( I! `: _. [7 q
/ y& t8 G2 e) ~% O, s3 g图 6. UML 模型模板
7 j5 I" D2 _( Z! y8 }! t# h# `
3 p. i' ?( F; D
- b" n* R2 p  C! A7 u每个模板都专用于一个特定架构目的。通常情况下,定义系统的每个方面(记得“4+1”视图模型),您需要使用 Use-Case、Analysis 和 Design 模型。在本例中,我们还创建了一个架构愿景的草图和一个指定部署目标环境的拓扑。因此,Yummy Inc. 工作区包含以下模型(图 7)。每个模型都基于不同的 RSA 模板。4 L. u: f7 c3 {9 i8 l% W

! O/ T) g0 |7 ?% x  ]! X  f图 7. 用于描述 Online Catering 系统架构视图的模型
: K/ [" Y& t7 P. m% F
# w1 c" i; R0 i: `" d# J0 E1 S  I* n
& T% r, D1 v- l3 H请注意,我们可能已决定使用在 RSA 模板中提供的其他类型的模型,如 BPMN 模型(业务流程)或 Services 模型 (SOA)。
6 E# x3 k+ \; l: K2 }0 H5 y# F+ S/ _现在您的 RSA 工作区已准备就绪,您需要执行我们在前面提到的几项活动。让我们来说明 RSA 如何在架构分析的每一个步骤中帮助您。
/ V* Q6 M  i- f+ n4 [, Q

9 O0 \" n2 |7 Q  x6 A" w1 S. ?* B1 l/ `. ]! ]
构想架构# z0 j$ m( U' W" W
作为软件架构师,您需要构想最初的架构,并制定指导开发和测试的架构决策。这项工作依赖于在类似系统中收集的经验,以及约束架构和用于架构的问题域。您的结论应该产生可以与团队沟通架构的信息。( t5 R. }$ A$ J( ?
确定重要需求" @- ?; t+ [1 |0 j3 R- }! O& D
您在架构构想中要完成的首要任务之一就是确定对于架构有重要影响的需求。作为一名架构师,您的职责是确保目标架构是​​适用的,可以满足用户需求。因此,您需要检查用例、业务流程或用户信息,确定那些对架构可能产生重大影响的需求。经验丰富的架构师通常会与项目经理或产品所有者密切合作,向他们灌输产品库中各项目对架构的影响。他们会影响产品库的优先顺序,从而尽快解决技术上的不确定性。1 L, ~% D' z+ E) d0 N
在 RSA 中,Use-case 模型包括 Yummy Inc. 的已确定需求(图 8)。! A$ t2 L: m; H. n6 f( n) Q5 d

7 f0 ^  Q+ ]4 O: C图 8. Online Catering 系统的需求1 k, l' r( u, Q  s

$ ]2 N% p" w. H- F- `. i# V  f/ f
确定重要需求并没有通用的规则。具体操作取决于您的环境、技术框架和项目团队。某个团队认为对架构有巨大影响的需求对于另一个团队而言可能是微不足道的需求。要求显示一个简单的项目列表的需求对架构的影响可能不是很大。但是,如果该需求是通过一个异步服务调用来获得业务合作伙伴的项目,那么您就必须确保您的架构中有支持该需求的管道。
% A) L7 g5 {8 o& @" I! v* B$ I在我们的 Yummy Inc. 示例中,模型分为多个面向功能的包。每个包中都含有相关的用例和操作员(跨领域操作员被划分到多功能包中)。通过用例图说明需求(图 9)。当然,在业务流程图或用户故事中,可能已捕获了相同的信息。
$ B) S. H5 b! d2 k) D- M" b. R- _9 N6 H9 N0 u7 S5 f0 @9 j
图 9. Order Menus(菜单)用例图
; o* T' e1 A% X$ {9 N+ Y! Z6 Q # ^6 H( i/ c2 z' F0 j. W0 W3 |
, f: d. U7 @3 e* X
定义候选架构" L  O# y9 |! w7 U; P1 R. D
确定重要需求后,软件架构师要创建一个架构概述。如今,我们很少从头开始开发系统。我们丰富了现有的应用程序,将遗留的系统现代化,并重用和组装资产。架构师可以利用过去在类似系统方面的经验,确保能够同时考虑到目标和约束。候选架构既会考虑系统的功能性需求(用例、故事、业务流程),也会考虑系统的非功能性需求(可用性、性能、可扩展性等等)。3 B* p2 j/ H' }. J$ D/ I& ^
在我们的示例中,我们已经选择了一个 N 层架构(图 10),架构中的应用程序是基于 Web 的,可以通过 Web 服务从不同类型的客户端访问它(有关多层应用程序的更多信息,请参阅 参考资料  h8 H8 p7 s% Y
请注意,技术图(图 10)是在 RSA 中创建的,在该阶段完成此创建非常简单,在很短的头脑风暴会议中就能完成。该图显示了所涉及的主要组件,以及已确定的开发解决方案的技术堆栈。7 `7 V& D, E" a
! U# r- V4 \, E) s8 `* H8 ?
图 10. Online Catering 系统的 N 层架构草图
; Y" i5 o* [/ p; F/ I# `
, G' S4 I) z/ g) S/ y# [" F6 X) I3 k. n) n
定义初始部署模型7 q# Y5 n' \" W4 b3 {! y
使用之前勾勒的架构概述,软件架构师现在可以画出部署模型的全图。它描述主要软件和硬件组件,以及它们在高层次如何互动。部署图考虑到部署环境的约束,并且是开发团队和基础加构团队之间良好的通信工具,可以实现两者之间的信息共享。/ p3 U2 ^  W; ]4 M1 m, S4 _8 c3 C
UML 规范提供了一组定义部署模型的元素。然而,UML 的部署部分已证明是功能有限的。因此,它没有得到行业的广泛采用,即使在密集型 UML 用户中也是如此。RSA 提供了大量的工具集来定义部署拓扑(逻辑、物理和部署实例)。RSA 拓扑非常强大,UML 部署模型则在以下方面显得有所不足:简单性、重用性和可追溯性(有关部署拓扑的更多信息,请参见 参考资源)。
; m# J8 A! z1 U, L部署图(图 11)显示了托管应用程序所需的不同硬件组件。RSA 自带了一些图库,可以使您的图表更有意义,它还允许您添加自己的图像来表示特定的模型元素。* O: a" ~8 \1 g% [! e& r9 f

* ^" i& g2 [- I& ~, P" a# [图 11. Online Catering 系统的部署节点8 w' D5 s9 a& ]% ^1 [8 I7 }! j0 D, B
; H0 j' S( R) c+ l: A
定义域模型# a' A  @( n+ P6 P. K1 `
对于业务应用程序而言,初始域模型可以帮助开发团队了解关键业务实体和它们之间的关系。软件架构师可以从功能性需求、用户素材或业务流程等各种来源获取信息。
  Q3 N$ m: \, n, m. f; T在 RSA 中,有一种简单的方法可以捕获业务实体,那就是利用分析配置文件。此配置文件包含您可以应用于 UML 元素中的三个构造原型(图 12)。& B# _8 G  L2 d' M

! n' A4 @% y% j: M6 ^图 12. UML 构造原型 (stereotype)5 J+ P2 W! T$ P8 t2 o

4 M+ B8 y0 }4 \$ N0 L( L1 [1 ?
/ n& n/ [4 [: c+ Z/ G$ e, V/ w& d' i) jBoundary 构造原型用于表示一个充当系统接口的类。Control 类描述一个执行对其他类的控制的组件。Entity 构造原型指定承载数据的类。  ?. L' {1 s5 C, g# o
在这个阶段,您只需关心数据,所以只使用实体构造原型即可。重要的是,要捕获将实现的系统的所有词汇。这是下一步将要创建的 Analysis Model 的出发点。
+ c/ k- }) G2 N由 RSA 提供的 Analysis Model 模板已预先架构好,并自带一个名为 Perspective overviews 的特殊包,用于收集与关键概念相关的信息(图 13)。: }7 [  w6 p( i' }' I& W
0 f3 `4 [% V( P# K9 ]
图 13. Online Catering 系统的 Perspective overviews' q( o' i  J! A6 p

2 W7 ]4 c% {$ z0 u
$ V- a4 C; ^, G" v  Z* k作为软件架构师,您可以使用一个简单的类图(含关键业务实体)来捕获使用分析构造原型的域模型的第一稿(图 14)。
# K: D% V5 X2 g2 A9 ?5 A) e% G8 J7 ~, O8 f( t/ T! g& J: k
图 14. Online Catering 的域模型. \0 t8 q( S, s; _( {+ g) g; j  D
* ?$ E' b( u, S! t/ [6 l' u

3 f3 f; i' i1 m. D! u. M还有其他可用来在 RSA 中定义域模型的选项。首先,您可以选择创建一个简单的草图来表示业务实体(图 15)。/ f' G( u' I2 n/ y' H+ F

6 T( [! O  `3 p7 A$ c图 15. Online Catering 的域模型草图# `. R8 D5 ]  I7 O& L

  Q8 b7 i' w5 g4 U" b2 i  @
, d' G5 T% p+ X6 Y( |( ?+ y$ C9 q在 RSA 中,当您需要更正式的表示法时,可以将草图元素转换为 UML 元素,并且可以在生成的 UML 和初始草图之间保持可追溯性。另一个选项是创建一个数据图。在 RSA 中,您可以在一个图中创建表、列和键来表示您的数据,也可以连接到您的数据库,导入现有的架构。选择使用哪个选项来定义您的域模型其实取决于您的环境和项目团队的工作方式。不可能有完美的解决方案,但肯定有一个最适合您的解决方案。: R# K. M) r; w  S


& @6 E7 \6 H* d' r7 X) w5 @5 j8 K3 b
结束语
: m( q5 k& D9 i0 x7 [# o0 J在这个阶段,您已经为您的软件密集型系统架构定义了愿景。您应该了解哪些视图对利益相关者是有用的,确定对技术解决方案有重大影响的需求,然后据此勾勒出目标架构。在很短的时间内(迭代 0),您就可以在 RSA 中捕获与技术、部署和域模型相关的关键信息。
/ S# v. s0 d3 e* ?, F8 j1 Z0 ~- j0 C* I/ q6 A
本系列的第 2 部分 中,您将看到如何使用 RSA ​​来优化您的软件密集型系统的架构。
$ Q, u, ^" J6 X8 P1 X3 i& a- q" s4 w; T3 }

0 B5 H; l( O# |% O' ?) R- _# N2 k) w) N下载
9 s" A& n5 b3 W, d' u; l
描述名字大小
Yummy RSA 模型84KB

0 w$ U8 `! V$ P0 A" B' P# L
4 n0 A* }  v: r5 Y; x8 h

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
 楼主| 发表于 2012-4-23 12:14:31 | 显示全部楼层
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

SCMLife推荐上一条 /4 下一条

QQ|小黑屋|手机版|无图版|SCMLife.com ( 京ICP备06056490号-1 )

GMT+8, 2018-9-22 12:07 , Processed in 0.066323 second(s), 6 queries , Gzip On, MemCache On.

Powered by SCMLife X3.4 Licensed

© 2001-2017 JoyShare.

快速回复 返回顶部 返回列表