SVN配置与使用[转]

SVN是一个自由、开放源码、跨平台的版本控制系统。它是一个通用系统,可用来管理任何类型的文件, 其中包括程序源码。  

SVN有两种运行方式,一种是基于Apache Http Server,另外一种是SVN Standalone Server。一般推荐使用基于Apache Http ServerSVN,这样做几个好处:

A.能使用WebDAV协议。

B.能使用浏览器作为客户端工具浏览源码仓库。

C.可以很容易的支持 到SSPI(Windows域认证)和LDAP,这些都是Apache本身就支持的。

D.能得到比较完善的Apache安全认证系统,比如 SSL加密连接。

现介绍在Windows下安装、配置SVN客服端和服务器端的方法,在此说明:这是一个快速手册,需要了解详细的配置信息请参考其他资料。

一.      安装Apache

http://httpd.apache.com/下载最新版的Apache For Windows,如版本apache_2.0.52-win32-x86-no_ssl.exe。注意如果IIS已在运行,需要先关闭(),或者更换IIS端口(),或者安装后更换Apache的监听端口()。如果安装Apache后没有更改监听的端口,又没有和IIS冲突。则用浏览器打开http://127.0.0.1/看是否能看到Apache的欢迎页。

二.      安装SubVersion

http://subversion.tigris.org/下载最新版的SVN服务器软件,如版本svn_server1.2.0.0.exe,接下来按下面的步骤对Apache和SubVersion进行配置

三.      配置Apache

1.在windows命令行提示符下,进入你Apache安装目录下的bin目录,使用命令建立Apache认证的用户:
htpasswd   -cm <你欲创建认证文件的绝对路径,如D:"Apache2"conf"usr_pwd> <新用户名称>
然后充分输入密码以确认。使用-c参数表示创建的新文件和首个用户,-m表示在usr_pwd中用MD5算法加密密码。
以后需要新建用户则使用参数-b,如:
htpasswd   -b <你欲创建认证文件的绝对路径,如D:"Apache2"conf"usr_pwd> <新用户名称>   <新用户的初始密码>
2.打开位于Apache安装目录下的conf目录下的httpd.conf文件。
在末尾加入如下的配置:
<Location /svntest>

    DAV svn

    SVNPath "F:"svn_repository"test"

    AuthType Basic

    AuthName "Subversion for testing"

    AuthUserFile "D:" Apache2"conf"usr_pwd"

    Require valid-user

</Location>

/svntest是客户端在导出(checkout)svn库时,在URL of repository中填写在服务器地址后的字符串,如:http://192.168.50.106/svntest

SVNPath是你欲创建的SVN库路径,创建方法在下一节。

AuthType表示认证类型,还有选项SSPI等,需要另外配置,这里使用Basic

AuthUserFile即你创建的认证文件的绝对路径。

四.      配置SubVersion

在windows命令行提示符下,使用命令:
svnadmin create <你的svn repository路径,如F:"svn_repository"test >
创建SVN库。

五.      安装和使用TortoiseSVN

在网上下载TortoiseSVN作为SVN的客户端,如:TortoiseSVN-1.2.2.4295-svn-1.2.3.msi。按提示执行默认安装,它是与window资源管理器结合在一起的。在你欲存储下载的SVN库的目录中点击右键->SVN Checkout,即弹出导出SVN的对话框。

在URL of repository中填写<服务器地址+ Location>,然后点击OK按钮,如图:

如果是第一次checkout,会弹出认证对话框Authentication,输入开始在Aapche中建立的用户和密码即可通过认证,如图:

在右键菜单中有个TortoiseSVN子菜单,其中包括了TortoiseSVN的所有功能配置和使用。现介绍比较常见的几个应用:

1.更新操作

客户端需要随时保持于服务器上的文件保持一致,所以经常要更新库中的文件。在你的SVN库目录下,点击右键,会有SVN Update菜单,点击后,TortoiseSVN会自动查找你未更新的文件并下载。如果你下载的文件和你现有的文件不一致,TortoiseSVN会自动合并不冲突的部分,那么在该文件前会显示Merged字样;如果有冲突,则会提示Confilicted,如图:


2.提交操作

如果客户端对现有文件做了修改并保存,那该文件的图标会是一个感叹号。在该目录下点击右键,会有SVN Commit选项,点击后,TortoiseSVN会自动查找你修改过的文件并列出,你可以输入注释,如修改文件的原因和时间等,然后在下面的复选框中选择欲提交修改的文件,然后点击OK,就完成提交。如图:


3.比较文件

如果在你的SVN库目录中,发现文件的图标中是一个“√”,那么是TortoiseSVN提示你的文件与服务器上的不一致,你可以选择右键菜单->TortoiseSVN子菜单->Diff,即可通过TortoiseSVN的文件比较器发现确切的差异。

4.添加删除文件等操作

客户端删除库中文件的操作是:
点击右键-> TortoiseSVN子菜单->Repo-Browser如图:



通过图中的右键菜单,可以对服务器上SVN库中的文件进行日志检查(Show Log), 导出(Checkout),创建文件夹(Create Folder),添加文件(Add File), 添加文件夹(Add Folder),删除文件(Delete)等等操作。
使用Repo-Browser菜单具有很强大的功能,它是直接在对服务器上的库进行操作。

5.冲突处理

对于库中的同一文件,如果有两个人都对其中的同一部分进行了修改,那么后提交的人就会在提交时获得该文件要求更新的警告,在更新以后,TortoiseSVN会提示当前工作的版本与服务器中的文件相冲突。这时文件的图标是一个感叹号。这时在该文件上点击右键,进入TortoiseSVN子菜单->Edit Conflicts,会弹出如图的编辑框TortoiseMerge



左上部是显示的服务器的文件,右上部是显示的本地文件,在下边是你处理合并后的文件,在TortoiseMerge中做的修改会反应到本地文件中,然后就可以提交。当然,你可以选择别的编辑工具编辑本地文件,以使其与服务器上的文件避开冲突。

6.锁定文件

为了防止冲突,TortoiseSVN提供了对文件的锁定功能。顾名思义,锁定文件以后,只能允许持有锁的用户才能对文件进行提交,其他用户在提交时会被提示文件被其他用户锁定,无法完成提交。使用锁定功能的方法是,在欲锁定的文件上点击右键,进入TortoiseSVN子菜单->Get Lock…如图:



在上部的输入框中输入你锁定文件的原因,在下边选择欲锁定的文件,然后点击OK即可。
当然,如果持有锁的人有事出差你不好问他的用户和密码,又必须修改他锁定的文件,TortoiseSVN在上图中提供了Steal the locks选择该复选框后,你即可以变成该文件的锁持有者,当然,你要准备好对原来的锁持有者回来后进行解释的充足理由。

7.恢复版本

有时由于提交了错误的修改,如果不想重新提交而是恢复到原来的版本时,可以在欲恢复为原来版本的文件上点击右键,使用TortoiseSVN子菜单->Update to Revision…功能,如图:



在文本输入框中输入你想恢复的版本号即可。

8.其他

TortoiseSVN提供了完善的日志记录,即经常可以见到的按钮Show Log,可以随时查看、关注某文件的修改记录。如果你还有精确到某文件的每一行被什么人、什么时间修改过,可以在该文件点击右键,进入TortoiseSVN子菜单->Blame…TortoiseSVN会用最详尽的方式为你提供参考。
TortoiseSVN子菜单->Settings对话框保含了对TortoiseSVN的常用配置,包括图标风格和配置服务器代理等等。
posted @ 2009-03-07 16:52  小鸡炖蘑菇  阅读(1889)  评论(2编辑  收藏  举报