求知 文章 文库 Lib 视频 iPerson 课程 认证 咨询 工具 讲座 Modeler   Code  
会员   
 
  
 
 
 
   
分享到
SVN版本管理配置
 

发布于2013-4-27

 

1 前言

1.1 目的

本文档对SVN版本管理常用命令进行说明,这里只说明了常用的几个命令,如果要了解更多,可以参考官方文档。

1.2 术语与缩写词

暂无。

1.3 参考资料

SVN中文站:http://www.subversion.org.cn/svnbook/1.4/index.html

2 命令环境说明

假定SVN已经安装完成,SVN指示的版本库磁盘路径为D:\svn_repository,假设有项目project是SVN正在管理的一个项目,所在版本库磁盘路径D:\svn_repository\project。假设从本机访问版本库,SVN协议访问的地址为:

svn://loccalhost:3690/project

注:端口3690依赖于安装时的配置。

如果配置了Apache服务器进行版本库访问,还可以在浏览器中访问:

http://localhsot:800/svn/project

注:端口800依赖于Apache的配置。

3 基本操作命令

3.1 从版本库下载项目

svn checkout http://localhsot:800/svn/project

简写:svn co http://localhsot:800/svn/project

3.2 查看文件修改状态命令

svn status

可以简写为svn st

文件的修改可以有很多方面,比如内容、属性等等,指示文件状态的有七列,分别说明如下:

第一列指出一个项目的是添加、删除还是其它的修改。

' '

没有修改。

'A'

预定要添加的项目。

'D'

预定要删除的项目。

'M'

项目已经修改了。

'R'

项目在工作拷贝中已经被替换了。这意味着文件预定要删除,然后有一个同样名称的文件要在同一个位置替换它。

'C'

项目的内容(相对于属性)与更新得到的数据冲突了。

'X'

项目与外部定义相关。

'I'

项目被忽略(例如使用svn:ignore属性)。

'?'

项目不在版本控制之下。

'!'

项目已经丢失(例如,你使用svn移动或者删除了它)。这也说明了一个目录不是完整的(一个检出或更新中断)。

'~'

项目作为一种对象(文件、目录或链接)纳入版本控制,但是已经被另一种对象替代。

第二列告诉一个文件或目录的属性的状态。

' '

没有修改。

'M'

这个项目的属性已经修改。

'C'

这个项目的属性与从版本库得到的更新有冲突。

第三列只在工作拷贝锁定时才会出现。(见“有时你只需要清理”一节。)

' '

项目没有锁定。

'L'

项目已经锁定。

第四列只在预定包含历史添加的项目出现。

' '

没有历史预定要提交。

'+'

历史预定要伴随提交。

第五列只在项目跳转到相对于它的父目录时出现(见“使用分支”一节)。

' '

项目是它的父目录的孩子。

'S'

项目已经转换。

第六列显示锁定信息。

' '

当使用--show-updates,文件没有锁定。如果不使用--show-updates,这意味着文件在工作拷贝被锁定。

K

文件锁定在工作拷贝。

O

文件被另一个工作拷贝的另一个用户锁定,只有在使用--show-updates时显示。

T

文件锁定在工作拷贝,但是锁定被“窃取”而不可用。文件当前锁定在版本库,只有在使用--show-updates时显示。

B

文件锁定在工作拷贝,但是锁定被“破坏”而不可用。文件当前锁定在版本库,只有在使用--show-updates时显示。

过期信息出现在第七列(只在使用--show-updates选项时出现)。

' '

这个项目在工作拷贝是最新的。

'*'

在服务器这个项目有了新的修订版本。

3.3 查看项目信息

svn info

3.4 增加新的文件到版本库

svn add file_name

file_name是要增加的文件,如果是目录,将递归增加。

3.5 更新项目到最新的版本状态

svn up

3.6 解决版本冲突

svn up或者svn ci时,如果文件第一列显示C表示这个文件的服务器版本与本地版本冲突(文件状态参见3.2),冲突的文件需要手工解决,解决冲突后,使用命令svn resolved告诉svn冲突已经解决。

3.7 放弃对文件的修改

如果修改了一个文件后,之后并不想永久修改它,也不必提交,这时候可以撤销对文件的修改,使用如下命令:

svn revert file_name

3.8 已修改的内容提交到版本库

svn commit –m “注释”

简写为svn ci –m “注释”

这条命令会提交所有的修改到版本库

3.9 更新列表的使用

有时候我们修改了很多文件,但是只想提交其中的一部分,这时候如果用svn ci命令提交,达不到这个目的。我们可以创建一个更新列表。

命令:svn changelist 简写svn cl

创建列表不需要专门创建,只要:

svn cl changelist_name file_name

同时创建了列表changelist_name,然后把file_name加入列表。

如果要把其他文件加入这个列表,命令相同,但不会再次创建,只会做加入列表的动作。

这时候提交动作也只需要:

svn --changelist changelist_name –m “注释”

简写为svn --cl changelist_name –m “注释”

3.10 查看版本更新日志

svn log

如果要查看指定版本的log,可以:

svn log –r versionNo,比如svn log –r 20

如果要查看某个版本的log及修改文件清单,可以:

svn log –r 20 –v

3.11 锁定文件

Svn的版本库理念是拷贝-修改-提交,与其他版本库的锁定-修改-提交概念不同,但是,如果你要修改一个文件,又不想别人修改时,可以使用svn lock命令,格式如下:

svn lock file_name

这对于二进制文件尤其有意义,比如一张图片,如果两个人同时修改,提交时才发现冲突,将有一方的工作需要放弃,等到另一方提交后,再做修改。解决办法就是修改之前,锁定这个文件。如果,其他人修改时,svn会提示他这个文件已经被锁定,这样就可以避免徒劳无功。

关于这个命令可以参考http://www.subversion.org.cn/svnbook/1.4/index.html了解更多。

3.12 删除文件

如果要删除一个服务器文件,可以使用一下命令:

svn delete file_name或svn del file_name 或svn remove file_name或svn rm file_name

3.13 重命名文件

如果想对服务器的文件或命令进行重命名,可以使用命令:

svn move src_name dst_name或

svn mv src_name dst_name 或

svn rename src_name dst_name或

svn ren src_name dst_name

这个命令也可以把一个文件或目录移动到另外一个位置。

3.14 导出干净的版本

从版本库用svn checkout出的工作目录下有隐藏的.svn目录,如果要导出干净的文件进行生产或者其他环境发布,可以使用以下命令:

svn export svn://localhost:3690/project

这个命令将导出最新版本。

如果要指定导出某个版本,可以增加参数-r,假定要导出第二十个版本:

svn export –r 20 svn://localhost:3690/project

3.15 导出某个文件

有时候你可能想导出某个文件的某个版本,可以

svn export –r 20 svn://localhost:3690/project/file_path/file_name

3.16 版本比较

svn diff file_name比较一个本地修改和本地上个版本的差异。

如果要指定比较某两个版本,可以:

svn diff –r 20:21 file_name

3.17 版本库地址切换

如果我们的版本库地址改变了,比如ip地址、机器名变更,原来的版本库地址可能是

svn://192.168.0.172:3690/project

或者

http:// 192.168.0.172:800/svn/project

现在变更为:

svn://192.168.0.175:3690/project

或者

http:// 192.168.0.175:800/svn/project

每个人电脑上的工作目录的版本对应的访问地址也需要做相应的改变,可以使用命令:

svn switch –relocate svn://192.168.0.172:3690/project svn://192.168.0.175:3690/project

或者

svn switch –relocate

http:// 192.168.0.172:800/svn/project http:// 192.168.0.175:800/svn/project

其中switch可以简写为sw。

3.18 SVN版本布局

Svn版本库的推荐结构

/project

/trunk

/branches

/tags

/trunk目录是开发主目录

/branches目录是分支开发目录

/tags目录是标记目录

几个人的团队很少出现需要分支开发的情况,所以/branches基本上很少用。

每次上线,我们可能希望保留完成的上线版本文件,同时又能看到这个版本之前的历史 版本,/tags目录可以发挥作用。上线时,可用如下命令创建上线版本:

svn copy svn://localhost:3690/project/trunk

svn:// localhost:3690/project/branches/release_1.0 -m "第一个上线版本"

3.19 使用SVN管理的项目Eclipse/MyEclipse配置

在eclipse左侧Package Explorer视图上右击项目,选择属性,在弹出的属性窗口上单击Java Build Path,然后选择souce,如下图:

双击Excluded,如下图,点击Add… 输入**/.svn/**即可。

以上配置的目的是确保,.svn目录不会被编译到classes目录,否则可能会操作失误导致版本错乱。

3.20 创建版本库

打开cmd窗口,运行

svnadmin create d:/svn_repository/project

project项目的版本库被创建。

3.21 导入项目到版本库

project项目的版本库创建后,需要把project项目纳入版本管理,命令:

svn import d:/huilan/project file:///d:/svn_repository/prject -m "初始版本"

其中d:/huilan/project是project项目目录

file:///d:/svn_repository/prject是版本库目录

3.22 文件忽略

有时候用svn st查看文件状态,有很多临时文件或者不想纳入版本控制的文件出现在窗口中,混淆视听。如果有忽略某个类型的文件,比如*.bak、*.tmp、*.class,可以做如下配置:

在windows运行窗口运行%APPDATA%,然后进入subversion目录,打开config文件,去掉对global-ignores的注释,同时在后边添加*.bak *.temp *.class等希望忽略的文件类型。

3.23 访问权限

要控制访问权限,可以修改版本库的配置信息。

d:/svn_repository/prject/conf目录下的svnserve.conf 、passwd、authz就是控制访问权限的。

svnserve.conf

anon-access = none匿名存取权限,none是不能匿名访问

auth-access = write授权访问权限,可写

password-db = passwd用户密码文件passwd

authz-db = authz用户授权文件authz

passwd

以键值对的形式记录用户和密码,比如

zhulin=zhulin

这就创建了一个用户zhulin密码为zhulin

authz

[groups]

用户组,有时候你想给你一群人分配相同的权限,这个就类似权限组,然后再给权限组赋相应的权限

[/project:]

Project项目权限

以下创建了一个dev用户组,它包括两个用户zhulin,xiyf,他们的权限为read、write即读写,当然还可以创建别的用户组和用户,并赋予不同的权限。

[groups]

dev=zhulin,xiyf

[/project:]

dev=rw

3.24 获得帮助

svn help或者svn h将列出svn可用子命令

svn h command_name将列出command_name 的使用说明

比如svn h add,看看效果如何。


   


软件配置管理的问题、目的
软件配置管理规范
CQWeb 7.1性能测试与调优指南
为什么需要使用ClearCase
ClearCase与RTC的集成
利用ClearQuest 进行测试管理
更多...   


产品发布管理
配置管理方法、实践、工具
多层次集成配置管理
使用CC与CQ进行项目实践
CVS与配置管理
Subversion管理员


配置管理实践(从组织级到项目级)
通号院 配置管理规范与应用
配置管理日构建及持续集成
丹佛斯 ClearCase与配置管理
中国移动 软件配置管理
中国银行 软件配置管理
天津华翼蓝天科技 配置管理与Pvcs