版本控制软件SubVersion 入门

 
版本控制软件 SubVersion 入门
前言:最近一直在不同机型上面移植项目,或者在以前的功能基础上添加新的功能,因为这家公司以前幼稚到未用版本控制工具来进行源代码的控制,现在又是几个人编辑同一份源代码,其效率之低可想而知。真是"你方改完我上场"啊。
先引用句名语吧:
        "即使你的团队只有你一个人,你的项目只需一周的时间;即使那是'用过就扔'的原型;即使你的工作并非源码;确保每样东西都处在源码控制之下--文档、电话号码表、给供应商的备忘录、makefile、构建与发布流程、烧制CD shell 脚本--每样东西。 "( 《程序员修练之道》 )

对于每一个程序员来讲,怎样能够最好的保护你的源代码都是最重要的一件事。一个源码控制软件就相当于一个系统级的 Undo 键,当你的程序可用时,作一个标记,当程序被改的体无完肤不能运行了,你可以方便的回到上一个可用的版本,或者当你发现自己想找回上周被你删除的一个函数的时候,你可以很容易的做到这一点。

当然,好的版本控制并不止于此。对于团队开发来讲,你可以控制每个人的分工和权限。两个人可以同时编辑同一份源代码,由程序来提醒两次修改中存在的冲突。你可以查看某一处改动是谁做的。当你发布了一个正式版,可以建立一个分支,在分支上继续开发下一个版本,而对于后来发现的 Bug ,可以在主分支上继续改进,如果分支上同样存在这个 Bug ,可以将两者合并。只要修复一次就可以,这不是很诱人吗?

目前业界流行的版本控制系统有很多,商业软件比如 ClearCase ,配置复杂,功能强大,价格也同样对得起它的功能。而 Visual Studio 自带的 SourceSafe 与它的开发工具完美整合,使用方便,但是对于其它语言和工具的支持就差一些了。开源世界最著名的版本控制软件是 CVS ,相当一部分的开源软件都在使用这个软件,以供全球的程序员协作开发。然而, CVS 有一些与生俱来的缺点,在设计之初没有考虑到,而随着使用量和使用状况的大增,慢慢显露了出来,比如,最重要的一点,它不支持文件改名,还有,只对文件控制版本,没有目录的管理,等等。

后来, CVS 的主要作者 (Fogel 等等 ) 在他们现任公司的资助下开发了 SubVersion ,用以替代 CVS SubVersion 的设计目的就是针对 CVS 的一些弱点进行改进。目前已经有几个知名的开源项目从 CVS 转向了 SubVersion 来保存源代码。 SubVersion 目前发布了 1.1 正式版,已经相当稳定可靠了。本文只是对 SubVersion 安装和使用入门的一点引导,以便从未用过版本控制的程序员可以快速上手,先从保护你的个人代码开始。

安装:
SubVersion
对于目前流行的大部分平台都有支持,可以到 subversion.tigris.org 下载各个平台的安装包,或者下载源代码在 linux 等平台上自己编译。对于 windows 平台,它也提供了安装程序。

一点说明: SubVersion 的运行分为两种情况,一种是作为独立的服务器,默认使用 3690 端口,像 CVS 那样来运行,支持直接连接或者 SSL 连接。另一种是借助 Apache2 webdav 功能,直接挂接在 apache 上,作为它的一个模块来运行。

这两种配置方式是各有优缺点的。首先,当 svn 独立运行的时候,作为一个轻型的服务器,反应速度和连接速度都要比 apache 要快一些。它有自己的用户认证方式,(使用系统中现有的帐号),它比 apache 更容易配置和使用。当用户以自己的身份登录以后所做的任何操作将被记录下用户名。以 apache 的模块来运行的时候,整个系统是以 apache 所在的身份来运行的,所有的用户(包括任何验证过的用户)都是使用这个身份的,那么你就没有办法区别不同用户的操作了。(有一个办法,就是让用户自己把名字写到每次 checkin message 里面)。它的优点是可以使用 apache 现有的架构,不需要去改动你的防火墙,而且,可以使用 IE 提供最简单的查看最新版本的功能。 Apache 有很多的认证方式,还有非常细致的对目录的权限管理,而且 apache 是一个安全、稳定的服务器。

具体使用哪一种服务器取决于你的需求,也可以几种方式一起用, svn 并不在乎这个。但是,为了容易管理和配置,建议你还是选择其中一种。(大部分人会选择 apache 的方式,因此本文只详细说明这种方式的安装和使用,对于 svn 独立运行的情况作为附属的章节供大家参考。)

Windows
上的安装:安装过程很简单,双击下载回来的 svn-1.1.0-setup.exe ,一路回车就可以安装好了,连必须的两个环境变量都帮你配置好了。在安装目录的 httpd 目录下有两个 so 文件,复制到 apache modules 目录中, bin 目录的 dll 文件复制到 apache bin 目录下或者系统的 system32 目录下,(取决于你的 apache 的运行状况),在 apache httpd.conf 里面找到两行:

LoadModule dav_module modules/mod_dav.so
LoadModule dav_fs_module modules/mod_dav_fs.so

确保它们没有被注释掉。然后在这两行的下面添加两行:

LoadModule dav_svn_module modules/mod_dav_svn.so
LoadModule authz_svn_module modules/mod_authz_svn.so

重启以后 svn 就以 apache 模块的方式来运行了。如果出现 apache 启动不起来的问题,看看 svn 命令是否在你的环境变量 PATH 里。 Linux 上的编译安装:对于下载回来的 .tar.gz 文件,用 tar zxvf 命令解压,进入解压出来的目录, ./configure-with-apxs=/path/to/apache/bin/apxs ,然后 make && make install ,安装完成时会自动修改你的 httpd.conf 文件,添加前面那两行,不需要你再做任何操作。

配置:
安装已经完成了,接下来要让它可用还需要两步操作。

首先要确定你保存某个工程的位置。比如你要把所有的工程放在 D:/repos 目录下,现在要建立一个工程 project1 ,在命令行输入: Svnadmin create d:/repos/project1

该命令会创建这个目录,并建立所必须的一些数据库和配置文件。然后到 httpd.conf 文件里添加对该目录的映射。 Svn 有两种映射方式,一种是针对每个项目,确定一个虚拟目录( Location ),另一种可以对一个总目录确定一个虚拟目录,其下的所有工程只要在该目录下直接输入工程名即可。第二种当然是要方便的多了。不过我们还是介绍一下第一种吧。在 httpd.conf 的任意位置(如果你需要在某个虚拟主机里面实现,就添加到那个虚拟主机的配置段)添加以下内容:(注意 apache 的配置文件里不能使用 / ,要用 / 来代替)

<Location /svn/project1>
DAV svn
SVNPath D:/repos/project1
</Location>

重启 apache 以后,在浏览器里输入 Http://localhost/svn/project1 ,应该就可以看到该工程的内容了,新建的工程会显示 Revision 0:/ 。使用这种方式,必须对你的每个工程都添加这样一段配置,而 svn 提供了另一个选项。

<Location /svn>
DAV svn
SVNParentPath D:/repos
</Location>

这样,该目录下所有的工程文件就都可以访问了。你同样可以输入上面的地址来验证一下。

如果要限制别人对仓库的访问,直接在该 Location 段加入任何合法的 apache 的权限控制命令就可以,比如:

AuthType Basic
AuthName "Subversion repository"
AuthUserFile /path/to/users/file

如果想让验证通过的用户有写权限,匿名用户有只读权限,可以在下面再加两行:

<LimitExcept GET PROPFIND OPTIONS REPORT>
Require valid-user
</LimitExcept>

具体的配置方式有很多,请参考 apache 的说明文档。

OK
,安装配置已经完成,下面可以开始使用了。

使用:
比如你现在要把一个现有的工程 Project1 要放入 svn 的控制之中,并且使用前面建立的那个数据仓库。打开命令行,进入你的这个工程目录,执行: Svn import . http://localhost/svn/Project1 -m "This is my project"

注意 import 后面是个点表示当前目录。如果不用点也可以,默认就是使用当前目录。

然后你会看到该目录下所有的目录和文件都被添加了。用浏览器打开上面这个地址,应该可以看到该目录下所有的文件和目录了。(切记, svn apache 的身份来运行,这个用户名需要有对该目录写入的权限。在 windows 上这通常不是问题,但是在 linux 上,你最好能够考虑清楚一些)。

这个文件列表是由 svn 模块生成的,如果你觉得太简陋,可以写一个自己的 xslt 转换文件,添加到配置段。具体信息参照 svn 的帮助文档吧。

现在只是你的工程文件被导入了,你的现有文件并没有在 svn 控制之下。你可以删除你原来的工程目录了,(安全起见,还是给它改个名字比较好)。到上层目录下执行: Svn checkout http://localhost/svn/Project1

该命令会自动在当前目录下建立 Project1 目录,并下载回仓库中所有的文件。该命令还有很多参数,比如指定要建立的目录的名字,或者指定要导出的版本号等等。

现在该工程中每个目录下都有了一个 .svn 的隐藏目录,以后某个文件被改动了以后,用 svn status 可以查看, svn checkin 可以将所做的更改放入仓库中。具体可用的命令还是去看 subversion 的使用手册吧,(安装以后的那个帮助文件),这份文档还是详细读一下比较好。还好,有中文版,只不过是繁体的: http://svn.ntcu.net/svnbook/book.html

如果所有的命令都要这样输入, 是不是太慢了? 可以使用可视化的管理工具 TortoiseSVN 在这里下载: http://tortoisesvn.tigris.org/ 。该工具与操作系统整合,给各种类型的文件标上不同的图标,并且可以以可视化的方式显示所有的变更记录,使用起来非常直观,也非常方便,而且提供了多国语言包,包括简体中文,我们就不多说了,一看就明白。另外,对于使用 eclipse 的用户,还有一个插件可用, http://subclipse.tigris.org ,这两者结合使用,功能相当强大。

以独立服务器的方式安装:
如果你只是在自己的机器上装上一份来对自己的日常工作提供版本控制功能,或者你没有 apache2 ,也不想安装这个东西,那么,把 svn 安装独立的 server 也是一个不错的选择。

实际上,在 windows 上安装完成以后不需要做任何操作你就可以开始使用了。按照前面说的方法新建一个测试用的库: Svnadmin create d:/repos/test1

然后随便找个目录导入一下试试看:
Svn -import . file:///d:/repos/test1 -m "just a test"

是不是成功了?这样的命令方式只能在本机上使用。要启用 svn 伺服器,只要在命令行上运行 svnserve -d 就可以了。很简单,不是吗?再试一下(打开另一个命令行窗口,这个一定不能关闭啊):

Svn -import . svn://localhost/d:/repos/test1 -m "just a test"

这个网址看上去有些奇怪,到你的运行 server 的命令行窗口中,用 ctrl+C 终止它的运行,再使用 svnserve -d -r d:/repos 来运行它,这样 server 就知道你的版本库的默认目录是什么了。然后再导入和使用的时候,地址只要写 svn://localhost/test1 就可以了。

linux 上也是一样的,配置的时候可以不用 -with-apxs 了,直接 configure ,然后 make && make install 就可以了。运行 server 的命令也是一样的。

如果要把 svn 作为一个后台服务来运行怎么办呢?总不至于一直让它开着一个窗口吧?万一不小心关了 …… linux 下要把它作为后台服务很简单,其实只要在命令的后面加上 & 就可以了,也就是通用的形式: svnserve -d & ,这样它就会在后台一直运行下去。或者你也可以让它使用 xinetd 的方式来运行。但是在 windows 上,就比较麻烦一些了,因为作者没有考虑到(或者说没有考虑)使用者的这个要求,因此,它不能像 apache 那样容易的把自己安装成服务,不过既然使用者都是程序员 …… http://dark.clansoft.dk/~mbn/svnservice/ 下载一个专为这个任务而写的小程序就可以了,使用方法在这个网页上有详细的说明。

在这种方式下如果要进行用户控制,可以使用 ssl 协议的方法,那么,地址就变成 svn+ssl://localhost/test1 了,但是这种方式要求 windows 上有可用的 ssl 客户端。也可以用密码文件的方法,打开你的 d:/repos/test1/conf 目录下的 svnserve.conf ,将
anon-access = read
auth-access = write
password-db = passwd
注释去掉, passwd CVS 一样是使用 apache htpasswd 程序来生成,放在该 conf 目录下即可。另外提一句, apache 验证如果使用 basic 方式的话,你在浏览器端输入的用户名和密码是以明文在网络上传输的,这并不是很安全。而 svn 的客户端在使用这种密码文件方式验证的时候,在网络上传输的只是 md5 值,比 apache 还要安全一些。
 
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值