CVS使用手册
上一篇 / 下一篇 2008-05-25 15:37:35 / 个人分类:测试工具
CVS是一个C/S系统,多个开发人员通过一个中心版本控制系统来记录文件版本,从而达到保证文件同步的目的。工作模式如下:
%~RS^N0CVS服务器(文件版本库)51Testing软件测试网c1\r c"Y ?
/ | \
4KWcpc`;d;?0(版 本 同 步)51Testing软件测试网5HL:s.V$x3}0\NM I
/ | \
?$u3\ UtB0开发者1 开发者2 开发者3
L0I5cv!y?3p f0
"s`7HV!O R]O0作为一般开发人员挑选2,6看就可以了,CVS的管理员则更需要懂的更多一些,最后还简单介绍了一些Windows下的cvs客户端使用,CVS远 程用户认证的选择及与BUG跟踪系统等开发环境的集成问题。51Testing软件测试网_'Lg%i9fB M
- CVS环境初始化:CVS环境的搭建 管理员
- CVS的日常使用:日常开发中最常用的CVS命令, 开发人员 管理员
- CVS的分支开发:项目按照不同进度和目标并发进行 管理员
- CVS的用户认证:通过SSH的远程用户认证,安全,简单 管理员
- CVSWEB:CVS的WEB访问界面大大提高代码版本比较的效率 管理员
- CVS TAG:将$Id$ 加入代码注释中,方便开发过程的跟踪开发人员
- CVS vs VSS: CVS和Virsual SourceSafe的比较 开发人员 管理员
- WinCVS:通过SSH认证的WinCVS认证设置
- 基于CVSTrac的小组开发环境搭建:通过CVSTrac实现web界面的CVS用户管理,集成的BUG跟踪和WIKI交流
- CVS中的用户权限管理:基于系统用户的CVS权限管理和基于CVSROOT/passwd的虚拟用户管理
一 个系统20%的功能往往能够满足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能还不到它全部命令选项的20%,作为一般开发人员平时会用 cvs update和cvs commit就够了,更多的需求在实际应用过程中自然会出现,不时回头看看相关文档经常有意外的收获。
'NfREMs{"F#~0CVS环境初始化
环境设置:指定CVS库的路径CVSROOT51Testing软件测试网:^%Sdd0xSR9lzm#btcsh51Testing软件测试网 _d$uiI#O
setenv CVSROOT /path/to/cvsroot51Testing软件测试网9n I4qq dwuL'C3{
bash
3?dYV$bXE0CVSROOT=/path/to/cvsroot ; export CVSROOT
后面还提到远程CVS服务器的设置:
:Pp*hL;I&l&D6{B0O0CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH51Testing软件测试网)I&Oa#R8o {p
m$b._+JnzAK}2j9q&U3a0初始化:CVS版本库的初始化。51Testing软件测试网@Z/u&X8GDb
cvs init51Testing软件测试网*`J$y/h q7M
一个项目的首次导入
gH&` v)D0cvs import -m "write some comments here" project_name vendor_tag release_tag51Testing软件测试网DO!E~,t;b)W
?(|
执行后:会将所有源文件及目录导入到/path/to/cvsroot/project_name目录下
]%Yl!@5x/i0vender_tag: 开发商标记51Testing软件测试网?"N"hq5l#z
_7w:P
release_tag: 版本发布标记
项目导出:将代码从CVS库里导出51Testing软件测试网 a2Z3Y;Rz6`M;l*^
cvs checkout project_name51Testing软件测试网O/a:O|t(}m d/ce"S
cvs
将创建project_name目录,并将最新版本的源代码导出到相应目录中。这个checkout和Virvual
SourceSafe中的check out不是一个概念,相对于Virvual SourceSafe的check out是cvs update,
check in是cvs commit。
+s\/F,~HI0?tMt0
p0W8OVh._'[051Testing软件测试网;V5s$lk_Ge?5F3n
CVS的日常使用
51Testing软件测试网1q?.^0p4c`'sc'A/v#J?0
3s}+Dx\T%[;lv0注意:第一次导出以后,就不是通过cvs checkout来同步文件了,而是要进入刚才cvs checkout project_name导出的project_name目录下进行具体文件的版本同步(添加,修改,删除)操作。
$ZEK8z,M:W0{.G05q5QG*]$d5iO0将文件同步到最新的版本
~GRbsZ$D8Kj0cvs update51Testing软件测试网wQ&GZ#M
不制定文件名,cvs将同步所有子目录下的文件,也可以制定某个文件名/目录进行同步51Testing软件测试网@/Whx|.c0L%F}
cvs update file_name
O
z U5Y8B&MB? @[0最
好每天开始工作前或将自己的工作导入到CVS库里前都要做一次,并养成“先同步 后修改”的习惯,和Virvual
SourceSafe不同,CVS里没有文件锁定的概念,所有的冲突是在commit之前解决,如果你修改过程中,有其他人修改并commit到了CVS
库中,CVS会通知你文件冲突,并自动将冲突部分用51Testing软件测试网PPI4om&E;a0~.m9V
>>>>>>
)bQ2V!@'A z`r0content on cvs server51Testing软件测试网)VL0B3{}5y
<<<<<<51Testing软件测试网M-y n-e&Yy
content in your file51Testing软件测试网8t*P4a/QP
>>>>>>51Testing软件测试网&RH-EF G_6Wd-r0R
标记出来,由你确认冲突内容的取舍。
6Yk6@'T*u@t0版本冲突一般是在多个人修改一个文件造成的,但这种项目管理上的问题不应该指望由CVS来解决。
p)K2{1T2V0确认修改写入到CVS库里51Testing软件测试网*j.V9fP e-E
C
Pz
cvs commit -m "write some comments here" file_name
注
意:CVS的很多动作都是通过cvs
commit进行最后确认并修改的,最好每次只修改一个文件。在确认的前,还需要用户填写修改注释,以帮助其他开发人员了解修改的原因。如果不用写-m
"comments"而直接确认`cvs commit file_name`
的话,cvs会自动调用系统缺省的文字编辑器(一般是vi)要求你写入注释。
8Aj4j|_}E0注释的质量很重要:所以不仅必须要写,而且必须写一些比较有意义的内容:以方便其他开发人员能够很好的理解51Testing软件测试网g1MB1o+W
qV(\#Y
不好的注释,很难让其他的开发人员快速的理解:比如: -m "bug fixed" 甚至 -m ""
{$V6j(|3r0好的注释,甚至可以用中文: -m "在用户注册过程中加入了Email地址校验"51Testing软件测试网#yjQ;m:n
y%\
!U7H6V1X{0修改某个版本注释:每次只确认一个文件到CVS库里是一个很好的习惯,但难免有时候忘了指定文件名,把多个文件以同样注释commit到CVS库里了,以 下命令可以允许你修改某个文件某个版本的注释:
-w,hpyE0cvs admin -m 1.3:"write some comments here" file_name
pY-jey4VY051Testing软件测试网,OG~r?uz\ \
添加文件51Testing软件测试网.S!JT rQn+T8X
创建好新文件后,比如:touch new_file51Testing软件测试网z]M6Np0@
cvs add new_file51Testing软件测试网Gd;~ hy8I$@S
注意:对于图片,Word文档等非纯文本的项目,需要使用cvs add -kb选项按2进制文件方式导入(k表示扩展选项,b表示binary),否则有可能出现文件被破坏的情况51Testing软件测试网2L~~L#y)j
比如:
l?;x"n"I`sv0cvs add -kb new_file.gif51Testing软件测试网 J'p6`&j[Q!N-B9k
cvs add -kb readme.doc51Testing软件测试网2?-X*L |Hw%@!y5HaTZ
如果关键词替换属性在首次导入时设置错了怎么办?51Testing软件测试网Qkk!UM(Z
cvs admin -kkv new_file.css51Testing软件测试网;lwk
d2d*qJ
k
51Testing软件测试网e3@sDv-Wg
然后确认修改并注释51Testing软件测试网1?+n3q-Akdd6t
cvs ci -m "write some comments here"51Testing软件测试网[8rm8~o4[FEe&j[y
.I{w0V\8{Ai0删除文件
t"Y5tm;p0将某个源文件物理删除后,比如:rm file_name