SCMLife.com

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 7570|回复: 2

[推荐] 从传统的SVN转向基于RTC的协作化软件配置管理

[复制链接]
发表于 2011-6-23 00:07:28 | 显示全部楼层 |阅读模式
本帖最后由 技术狂人 于 2011-6-23 00:12 编辑
7 C# H; ^% a# G; Z/ x$ p# n& k' c
引言7 L) @! o3 o# v6 c( Q
Subversion(SVN)是一款众所周知的开源的传统代码管理工具。由于其安装和使用简单的特点,能满足基本的代码管理需求,所以被广泛使用。IBM Rational Team Concert(RTC)是构建在 IBM Rational 面向软件交付技术的下一代协作平台 Jazz 平台上的第一个商用产品、一个协作式的软件开发环境,它包含了集成的源代码控制、工作项管理和构建管理等功能。RTC 可以说是一款强大的跨时代的开发管理工具。从其名字中我们就可以看出,它不光是针对代码管理,更注重于将代码管理集成到整个代码的开发周期和团队协作中去。作为产品级开发管理平台软件,有其创新的代码管理的理念及独特实现方式。
* u9 b* @- D: w3 I$ D. r# p2 l1 I6 A. ]& P; p
本文将面向熟悉 SVN 的 RTC 普通用户,介绍了如何从传统的 SVN 代码管理平台向 Rational Team Concert 2.0 进行迁移,和 RTC 的代码管理理念和方式,以及一些笔者在 RTC 实践当中的小技巧。7 C( ~3 J( B8 _1 E
9 V) M! y$ ]) }) o
在做代码管理迁移前,首先要理解 SVN 和 RTC 在代码管理中一些基本元素和概念的差别,以及两者之间的相似之处。3 P% j1 `) D0 z, D

, S! |' A1 F6 j3 s9 Z( d
Subversion vs. Rational Team Cconcert 源代码管理中的差异3 v! G8 W+ D' n8 E
Check-In/Out 的基本单位$ V! y( r& _7 g+ j3 a) F
SVN 中,文件是最基本元素,即使当你对一批文件进行 Checi-In/Out 操作时,实际还是对每个文件进行 Check-In/Check-Out。4 I) ]) o$ D1 I6 |% d  U
RTC 中,是以 Change-Set 为最基本单位进行操作。如图 1 所示在一个 Change-Set 中,可以包含若干文件和目录。+ g4 N+ H( |4 n7 X

$ ^' g0 |& k! e7 |# m& J图 1. 在 RTC 中,是以 Change-Set 为最基本单位进行操作4 i1 u7 }1 [( v7 h: w

& m2 l' O' V2 U- N2 H+ y, h
# h' i4 `, v% J1 H7 C# G; MRTC 中的代码变更是一个变更集的概念,以一批文件或目录的变更作为一个变更集 Change-Set 来进行管理。这一特性将贯穿到整个 RTC 的代码管理中。
6 P; @1 _/ w0 G9 E- j. s5 l7 C/ \8 y- W
Check-In/Out 控制环境
4 I; Y6 c/ d/ R( G& L( GSVN 中,以命令行方式,或者借助于第 3 方的软件,类似 SmartSVN,TortoiseSVN,RapidSVN 等进行代码的 Check-In/Out 操作。当然也可以通过一些插件与流行 Eclipse 开发环境集成在一起。1 p# E9 t) L" S& _( Q
RTC 中,则与 Rational 系列软件开发环境(Eclipse)集成在一起。将代码管理控制与 Rational 系列开发工具(Eclipse)紧密集成在一起,将充分发挥 Rational 系列软件套件的优势。
+ |1 B4 @- E( ], x2 T# \. }) r/ g( k% m% C) k0 s6 y
Check-In/Out 版本控制: o5 q3 |' M. q, `
SVN 中,每次 Check-In 都会生成一个独立的版本号。会给每个 Check-In 的文件或目录打上同一个版本号。Check-Out 时,可以指定版本号进行 Update。
8 ?% F6 C6 t8 p: p1 ^/ E. j' a0 F5 eRTC 中,没有了这个版本号概念,这是个区别与以往传统代码管理工具很大的特征。对于如何通过版本号来追溯以前的修改,RTC 中同样提供了 Show History 的功能,如图 2 所示,任何一次的变更集,都可以追溯的到。可以通过 History 来 Discard 任何一次 Change-Set,来回滚到之前的版本% I- V; N. |+ Y+ D# f

3 c' k- K1 j3 s& {! O. d) J4 Y& \/ H图 2. 变更集都可以追溯的到# V/ d+ A, X/ D/ y! e
2 I! o: L# W  a. [/ o5 W
, \$ \$ c; E, t# y2 t+ c
对于其他开发者 Check-In 的 Change-Set 可以有选择性的更新到本地开发环境。如图 3 所示对于其他开发者的提交的 Change-Set,开发者在 Accept 到本地开发环境之前,可以查看到作了什么修改,可以选择立刻 Accept 到本地开发环境,或暂时不接受以不影响本地开发,以后再 Accept 下来做 Merge。
! D9 H. E6 L1 |! H( w- @' [% g
3 S2 a) `4 U1 D# m/ A* u) D图 3. 其他开发者的 Change-Set 可以有选择性的更新到本地开发环境% ~6 m7 e* X1 j+ q/ R/ c
2 j1 v: |4 Z$ z2 b2 }

) m  C" @) D$ Q: }) K! RRTC 独特的 Change-Set 概念可以让开发者更好的处理每次代码的变更,其灵活性这在以往传统的代码管理工具中,是无法做到的。
. c& m# C. f- z9 d* `
) n0 R+ S% z  n0 q; q/ }Tag vs. Base-Line 的差异
; U9 T4 }& c- _说到这里不得不提一下,对于大的变更的版本控制了。
' O# n. `' A9 @6 Z) \SVN 中,可以通过对当前的代码打 Tag 来进行一次大的变更的记录,其实质就是在服务器端做一次镜像的 Copy。6 A4 q2 Q1 {1 I3 M. ]1 e
RTC 中,可以通过对选择一些 Change-Set 集来进行做 Base-Line。其灵活性就在于,你可以根据不同的需求对 Change-Set 挑选,来做一次大的变更的记录,而又不会影响现有团队的开发。而且不同的 Base-Line 可以是有重叠的 Change-Set,也可以没有任何联系。* H, `" D/ N- K6 ~. Q/ z0 N

: `9 J; n) O+ F7 B& f4 H5 qRTC 以其特殊的 Base-Line 管理方式,极大的方便了对于不同目的的大变更的记录以及追溯。这也是目前其他市场上任何代码管理工具都无法做到的。( d3 P: ~# `% u& l- n/ M

% _# b2 k" @6 J/ A代码变更与 Bug Tracking 的相结合。
; d: D8 k& f* P: mSVN 中,本身不具备这一功能,但可以使用第三方的工具,例如 JIRA 的 SVN 插件,可以将 Bug Tracking 和代码相结合。3 j( J3 r3 @4 {, H
RTC 中,本身就已经集成了 Bug Tracking 功能。可以在 RTC 中,建立类似于 JIRA,Maintis 等 Bug Tracking 工具的 Work Item,将代码变更集(Change-Set)与 Work Item 做关联,可以方便的查阅。如图 4 所示4 ^9 R- v- U( w' D( I1 ^
$ z+ n$ ^$ `' @. y4 [4 C* c; W
图 4. RTC 中集成的 Bug Tracking 功能
: }9 x( y) o) O% R4 a$ U9 f: j3 L, O1 H5 S5 Z# }" C+ @) q

7 s8 Y6 P& B, a, @& }RTC 中内嵌了 Defect 管理和跟踪功能,可以和所作的 ChangeSet 作无缝关联集成,使其免去了另外构建 BugTracking 系统的成本,也使其超越了市场上任何一款商用代码管理工具。, {6 Y. ]" H- G
综上所述,如表 1 我们可以罗列出 2 者的差别6 k  t" M% N: a4 g7 [! q8 \2 D

2 T6 V$ @4 P7 y& q; S$ u# B表 1. SVN 和 RTC 的差异" D0 W3 f7 {) q% g1 @8 {' ]
比较项目SVNRTC
对于变更代码的控制的便捷性一般
版本控制的便捷性一般
与 Bug Tracking 的结合无(依赖第三方)
+ G% ]# f* F7 g' X. G# S
当然了,作为 IBM 一款明星产品软件,RTC 的功能远不只这些,这里只是阐述了针对代码管理这块相关的一些功能与传统工具的差异。  N& ^* @; d( q, D9 U- n
RTC 确实是个好工具,对于已经在用 SVN 的用户,如何把 SVN 的代码搬到 RTC 上去,主要有 2 种方法来实现。5 ?. w' K4 e0 c' ]5 m) V
关于 RTC server 的构建就略去不说了,大家可以参考 RTC 的文档,这里只针对代码迁移怎么实施这块儿简单向大家介绍。
& j! f+ K0 z8 h6 h' n: G
6 Z; K4 V- R& ]0 t* `% e) x

; @: J2 U# m' Y$ J6 b  m( k  T' \( ]1 P& S
将源代码从 Subversion 迁移到 Rational Team Concert 的两种方法
6 ^6 V( W! P5 |: t) }4 A1 H使用 RTC 中提供的 SVN 接口; e) O$ B5 m7 K% V" _7 J
步骤 1:将现有的 SVN 的代码文件导出成 dump 文件。如图 5 所示:
; F' `- g- L4 H
6 ^8 i$ [! F- e5 l图 5. 步骤 1
5 ~2 R; z. d' I! `+ \  G8 L; [! Y: A( v3 E8 q! M/ c. [
1 d/ Y2 l4 u8 X  t3 ?: v' @
步骤 2:在 RTC 中,选择 File/Import,如图 6 所示选择 SVN Dump File,按 Next。6 G$ i/ T' P( K, G
- X; b$ d# D; h! T) _; |* ?
图 6. 步骤 2
! t& S1 Z0 P0 ^# @+ G* @% }5 \4 F$ }6 P  X0 t

  Y# P/ _3 G1 t3 P步骤 3:根据 Wizard 提示,如图 7 所示选择刚才从 SVN 导出的 dumpfile,按 Next。
" H5 f2 S" D7 I* R: l4 @8 m: e6 Y! N& X' d1 z" F! o6 s* H$ p& @
图 7. 步骤 3) M/ p9 T! t# a, f, N! l

! t3 l  S: _- ~& R3 i' o1 o ; |+ v: g& v4 e( t" c
步骤 4: 如图 8 选择需要导入的 Component,按 Next。6 @  K7 R  c6 |/ \8 F3 ^
# `4 z$ ]5 s/ N
图 8. 步骤 4
3 Y% O; j. X( U2 R1 }# F8 M' J( c. R& a9 z$ O, X4 }' q6 M
- y5 e( n4 U3 ~7 t, c
步骤 5:如图 9 选择合适的 [Text file encoding],按 Next。; T' ]* J+ Y6 u+ X2 f( g  t  f
这里要注意 SVN 中的文件 encoding 是否统一为选择的 encoding。如果不事先统一 SVN 中文件的 encoding,否则会导致 import 失败。' t( V+ k4 P0 B. k+ }6 J
这里可以在 [Revisions to Import] 选择将 SVN 中的所有 History 版本都导入,或者指定版本导入。! v6 j3 H( G3 e, g$ K% N
如果不需要保留 SVN 中的 History 的话,推荐可以选择只把最新版导入。因为根据 Dump 文件大小,将所有 History 导入会非常耗时间。
5 O) N+ |- S/ n1 a$ [6 F- }
. I  O/ u" z/ N* k图 9. 步骤 5
+ P4 S+ Y) b0 |) S5 [7 t+ U0 n1 O" `5 q6 Q9 r: F$ h1 c
0 i4 J& ^3 X! X+ e# o7 h
步骤 6:如图 10 一般选择不导入 SVN 中的 User,按 Next 即可。
! v  E, ?  }- v8 g. p: O7 n4 `8 O2 V' `: M# i
图 10. 步骤 6
# t9 L6 j7 ^! f: S" S  y
( w8 I; Z3 h6 y% X. E. e 0 x9 d, r# N/ N$ a2 Y/ K# D* r* C
步骤 7:如图 11 所示,选择 Finish,导入即完成。
" g0 c5 g7 X" A6 g' j. Z& X7 I- i  c/ D: Y  w
图 11. 步骤 7
0 i$ ]2 q. |4 ^4 l; F5 [; ^$ A* _! K- N9 O( }

; L6 z1 A/ ?: B% v8 q作为新建文件导入
8 K! [8 N7 I: ^" U这种方式就比较简单了,就是将所有 SVN 的文件 Copy 到本地环境,然后将他们 Check-In 到 RTC 中。这里就不在做累赘说明了。( c) ~, ^8 ?7 v9 R/ s  U: K# y2 q
在正式开始使用 RTC 之前,要针对所有 Team Member 做如何使用 RTC 的培训。关于 RTC 介绍的资料有一大堆,本身 RTC 也自带了许多 Tutorial,都是很好的素材。这里就不做累赘的介绍了。下面是 RTC 使用中笔者的一些使用心得,相信会有助于增进读者对 RTC 的理解。- Y1 s1 r4 R: Y2 `+ n) A9 n


# ]# H0 S5 a! e; h" t9 e% W" ARational Team Concert 的使用心得
3 b0 X( Y9 g% rRTC 中的代码管理结构的规划) P* s3 k& ~' }8 y6 k- Q% v+ u
SVN 中,目录结构一般为如下的 3 层构架。; w" o4 J. U% q
SVN---- Trunk---- Branch---- Tag
" p# ^( L9 ^! H/ X3 D* l" G$ s5 i
对于如何在 RTC 中进行规划的问题,可谓仁者见仁,智者见智。如表 2 首先必须要理解下面几个重要名称的概念。" ?2 L' s3 m( I4 O( H4 c
( y, |0 i& [1 Q& i) _6 x" f- R
表 2. 几个重要的概念
# N0 x& b% V0 M  O* @4 q# |
名称含义SVN 中类似项
Stream存储代码的流,内含多个 Component。Trunk/Branch
Component存储代码文件的最小容器,可以按需求建多个。  v; p$ w1 j8 O3 W! J
Workspace建立用于开发的 Stream 的镜像代码' x2 k! D; j* a  B4 [
Base-Line基于 Change-Set 大变更记录Tag
Snap-Shot以 Stream 为单位的大变更记录Tag

% ~! Y2 Z* S1 C* N/ n' g# R实际使用当中,Stream 和 Component 可以灵活的按需构架,只要适合你的管理需要就可以。如图 12 为项目的不同管理目的构建了 3 个 Stream,分别为 Documentation、Main Development、Release。
; T1 u$ ]9 {6 a; t/ e  N5 ?4 y% N8 T  E$ N. s1 h
图 12. 为项目的不同管理目的构建了 3 个 Stream
/ B# f( o, B9 s1 W2 r
) j. n0 F  ?+ P 0 e0 j: }  d+ {; x- g
RTC 代码流转过程。
6 h- J" e* Z# Q9 v下面这张图 13,是大家所必需理解的。不同于 SVN,在 RTC 中,为每个开发者在 RTC Server 端建立了 Personal 的 Workspace,所有的变更在 Local 完成后,将先 Check-In 到 RTC 服务器上 Personal 的 Workspace。然后通过 Deliver 将变更提交到 Stream 中,使其他 Team Member 可以通过 Accept 分享你的变更。+ m7 ?" V& v- T. G& \. ?+ X$ r
! W& Y/ Z9 P! f4 @6 T- p8 Z, _, F' J. |
图 13. RTC 代码流转过程
: w5 L; {3 i9 g& G
- i; P: U' C- F: b9 u2 u7 l4 I
7 \2 L/ T6 v% K整个过程简单的说就是7 V& A7 k0 u! f$ N  N0 X( u# f
步骤 1:开发者 - 甲 Local 修改 -> Check-In -> Deliver to Stream
) ^4 }! ^) F& u3 l7 X步骤 2:开发者 - 乙 Accept(开发者 - 甲的修改)from Steam-> Load 到 Local0 [1 Y6 g5 R" y0 y9 K; ?9 g
比起 SVN 来,当中多了一个到 Personal Workspace 的环节,而且并非像 SVN 那样 Check-In 后,就可以直接和其他开发者共享代码。
0 t9 r4 `; @6 y# J- X基本操作心得
' A3 H/ k. Q# L$ V4 r具体操作过程中,如何识别 [ RTC 代码流转过程 ] 中的操作呢?如图 14 所示。
: h4 y# q6 Y( W/ C5 H, _/ O) }# y+ S' ?' \$ h
图 14. 识别代码流转操作
* C& f4 W' [% u  F) B5 \; I, O% A* B$ y( c& {

5 _4 G5 ^# d; B4 j  S[Unresolved] 是可以 Check-In 的变更集1 }$ F2 L7 e  R, C& M: s
1) 当你在 Local 更改了代码文件时,就会出现 Unresolved 目录,里面列出了所有的更改文件。
# `  J7 g2 g! Q" E; [/ M" S. |8 H( Y如图 15 开发者可以将更改过的文件,分成几个不同的 Chang-Set 来 Check-In。
* Q: U$ V. g+ V6 [1 s6 m4 I* L- m3 W  b1 q9 o$ \8 w" g
图 15. 分成不同的 Chang-Set 来 Check-In
' O0 c) b) w3 R5 c) j6 x0 k. D+ j  Q1 m5 c, j' e

9 R) P/ A9 T9 e+ k3 Q2) 所有 Unresolved 的变更可以通过 Undo 来随时撤销。
  P6 F' h( Q. L# P- Y* h现有 RTC 2.0 版本中,当你打开 Excel、Word 格式的文件,不对其做过变更而直接关闭,RTC 会仍然检测为变更过,实际使用时需要留意。或许在未来版本中会解决这一问题。3 t4 @. {$ f' _8 U
[Outgoing] 是可以 Deliver 的变更集
8 H( k' l  r7 D  D. a3) 当成功 Check-In 后,会在 Outgoing 目录中出现等待 Deliver 的变更集。; C) v+ e, C4 {$ M" G& x% A0 U
4) 对于还未 Deliver 的 Change-Set,开发者可以随时再次修改,再次做 Check-In。" P/ X( }( P  `+ U8 j( k8 j) x$ A
如果用户想把这次 Check-In 的东西固定下来,再次修改的变更作为一个新的 Change-Set 的话。如图 16 可以把已经 Check-In 的 Change-Set 标记为 Complete。就可以再次 Check-In 新的变更,而又不会影响到你上次作的变更,会在 Outgoing 中出现 2 个针对同一文件的不同的 Chang-Set。这也正是 RTC 对于 Chang-Set 概念的优势体现。4 K& Q" d) W( b( Y9 S

2 ^/ S' D5 N! r6 _% |+ ]+ u4 D: S6 J5 H图 16. 把已经 Check-In 的 Change-Set 标记为 Complete 就可以再次 Check-In 新的变更
: G: n4 F5 d2 D# V/ L* u( k3 e
3 W. ?3 |# [6 @. c" H& u* h
8 Y* d! {" k. x* ~; W5) 当我们做 Bug Fixing 的时候,会希望所修改的 Change-Set 和某个 Bug 作关联时,可以如图 17 所示,选择一个 RTC 中的 Work Item 来做 Associate。
6 t& f3 r, K  U: `
( I& p: q* j* k+ ^' T1 R图 17. 一个 Change-Set 可以同时和多个 Work Item 来做关联。
6 H  T. r) }: o* M+ t% i6 I4 x' w; J
* x0 n% h6 u1 c, C3 m
6) 当准备做 Deliver 的 Change-Set 与其他开发者的 Change-Set 有冲突时,RTC 中会显示如图 18,这时候可以做 Discard 自己的 Change-Set 或者作 Merge。这点要比 SVN 等传统工具更加人性化,当冲突发生时你可以事先知道,选择对应方法。
- V0 K: z6 g- j3 u. ^
* x0 K* I5 n# q2 c- ?图 18. 冲突# O+ R& z0 @8 ?+ ~9 ]8 k) w

9 w) H7 ]3 g7 R' [5 s9 h; Z; |/ V; q3 V8 D+ p
[Incoming] 是可以 Accept 的变更集2 W+ d& O% @" u' i; A) L* d
如果你 local 已经 Load 过关于这个变更集的 Component,当你 Accept 一个变更集时,会自动 Load 到你本地的环境中去。如图 19 显示为 loaded。
! E& [! S' ~$ r7 C
8 s# [1 w. x: V; H' `  R图 19. 已经加载的变更集+ }7 f9 g, W7 B, g% ]7 n

6 S4 e# P" Z+ |* _5 S9 a2 h
% n7 b/ d& O+ ?" W如果你 Local 没有 Load 过关于这个变更集的 Component,那么 Accept 将只是在服务器端操作。
. [. j$ H3 R  `' }% J: \# k- ?) ?! z

& |9 d/ G! G6 H7 Q6 y结束语  c3 M6 j  ~- Z& Y& T2 p
本文通过对 Subversion 与 Rational Team Concert 在代码管理上的比较,以及一些实际使用中的经验技巧的介绍,突现了 RTC 在代码管理方面的优势,希望能吸引更多的 SVN 用户向 RTC 管理平台的转移。; S4 V+ @4 U0 Z- f$ u( \0 `# y

本帖子中包含更多资源

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

x
 楼主| 发表于 2011-6-23 00:13:18 | 显示全部楼层
回复 支持 反对

使用道具 举报

发表于 2014-12-2 17:12:18 | 显示全部楼层
请问可以实现一台SVN服务器 与另外一台 RTC服务器的同步吗?
回复 支持 反对

使用道具 举报

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

本版积分规则

关闭

SCMLife推荐上一条 /4 下一条

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

GMT+8, 2019-2-19 20:04 , Processed in 0.065283 second(s), 6 queries , Gzip On, MemCache On.

Powered by SCMLife X3.4 Licensed

© 2001-2017 JoyShare.

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