`
huozheleisi
  • 浏览: 1231457 次
文章分类
社区版块
存档分类
最新评论

Windows下Subversion管理配置详细说明

 
阅读更多

在Windows下进行Subversion管理配置中,主要分为两个步骤,安装svnservice与进行Subversion备份,下面将为您详细的介绍一下主要步骤。

从Subversion1.4开始,Subversion本身就集成Windows服务的工具。我们不必像以前一样,必须依赖于svnservice或其他工具。

1,安装svnservice

在Windows NT中(包括Windows XP, Windows 2000, Windows 2003 Server)本身包含了一个安装服务的工具,叫做"Service Control",也就是sc.exe。例如我的Subversion安装在"D:\Subversion",版本库在"D:\svnroot",而我希望对应的Subversion服务名为svnservice,安装这个svn服务的命令就可以这样写:

  1. sccreatesvnservice
  2. binpath="D:\Subversion\bin\svnserve.exe--service-rD:\svnroot"
  3. displayname="SVNService"
  4. depend=Tcpip

请注意,因为便于察看,上面的命令分为多行,但在实际执行时应该在一行里。另外,在以前启动svnserve时会使用"-d"选项,也就是守护进程模式,在这里不能使用,会导致服务无法启动。同样,"-i"和"-t"选项也不能使用。在命令行窗口执行完这个命令之后,服务还没有启动,你可以继续运行"net start svnservice"启动这个服务,然后使用"net stop svnservice"停止服务。

另外还有两点需要小心处理。首先,如果路径中包括空格,一定要用“\”处理“"”号,例如上面的例子中如果svnserve.exe在“c:\program files\subversion\”中,则命令应该写为“binpath= "\"c:\program files\subversion\bin\svnserve.exe\"”(“”中的内容),整个命令如下,红色部分是改变部分。

  1. sccreatesvnservice
  2. binpath="\"D:\programfiles\Subversion\bin\svnserve.exe\"--service-rD:\svnroot"
  3. displayname="SVNService"
  4. depend=Tcpip

其次,sc对选项的格式还有要求,例如“depend= Tcpip”不能写为“depend = Tcpip”或“depend=Tcpip”,也就是“=”前不能有空各,而后面必须有空格。

2,删除服务

如果服务安装的有问题,你可能需要删除服务。要删除前面添加的服务,只需要运行"net start svnservice","svnservice"就是我们创建服务时使用的名字。

3,配置服务是自动启动

默认情况下安装的服务不会随Windows的启动而启动,为了使svn服务能够随Windows启动而启动,需要修改一下"sc create"命令(首先要删除),增加"start= auto"选项:

  1. sccreatesvnservice
  2. binpath="D:\Subversion\bin\svnserve.exe--service-rD:\svnroot"
  3. displayname="SVNService"
  4. depend=Tcpip
  5. start=auto

当然你也可以使用图形化的工具修改服务的属性,你可以在“开始->运行...”中执行"services.msc",然后在界面中修改。

Subversion的权限控制

1,认证(Authentication)和授权(Authorization)

这两个术语经常一起出现。其中认证的意思就是鉴别用户的身份,最常见的方式就是使用用户名和密码,授权就是判断用户是否具备某种操作的权限,在Subversion里提供了“authz-db”文件,实现了以路径为基础的授权,也就是判断用户是否有操作对应路径的权限,在Subversion 1.3之后,svnserve和Apache一样都可以使用“authz-db”文件。

2. svnserve下的配置文件

因为本文是以svnserve为例的,所以先介绍一下版本库目录的结构:

  1. D:\SVNROOT\PROJECT1
  2. ├─conf
  3. ├─dav
  4. ├─db
  5. │├─revprops
  6. │├─revs
  7. │└─transactions
  8. ├─hooks
  9. └─locks

其中conf下面有三个文件:

  1. authz
  2. passwd
  3. svnserve.conf

其中的“svnserve.conf”是这个版本库的配置文件,当使用svnserve时,这个配置文件决定了使用什么认证和授权文件:

  1. password-db=passwd
  2. authzauthz-db=authz

上面的配置说明使用“svnserve.conf”同目录的passwd和authz,其中的password-db指定了用户密码文件,authz-db是我们的授权文件,也就是我们本文主要介绍的文件。注意:使用Apache作为服务器时,根本就不会参考“svnserve.conf”文件的内容,而是会参考Apache的配置。

3,基于svnserve的版本库文件布局

使用svnserve时,为了管理的方便,应该使用相同的认证和授权文件,所以应该让所有版本库的配置文件svnserve.conf指向同一个password-db和authz-db文件。下面是一个多版本库的目录:

  1. D:\SVNROOT
  2. ├─project1
  3. │├─conf
  4. │├─dav
  5. │├─db
  6. ││├─revprops
  7. ││├─revs
  8. ││└─transactions
  9. │├─hooks
  10. │└─locks
  11. └─project2
  12. ├─conf
  13. ├─dav
  14. ├─db
  15. │├─revprops
  16. │├─revs
  17. │└─transactions
  18. ├─hooks
  19. └─locks

D:\SVNROOT下有两个目录project1和project2,都已经创建了版本库,所以我们修改每个conf目录下的svnserve.conf,使之指向同一个password-db和authz-db文件。

  1. password-db=..\..\passwd

authz-db = ..\..\authz这样,D:\SVNROOT\passwd和D:\SVNROOT\authz就控制了所有版本库的svnserve访问。另外在后面的操作中要关闭匿名访问,应该去掉“anon-access = none”前的“#”号,保证只有认证用户可以访问。

注意:还有一点需要注意,那就是svnserve的“realm”的值,在上面的设置下,应该保证所有的版本库使用相同的realm值,这样,对版本库的密码缓存可以在多个版本库之间共享,更多细节见客户端凭证缓存。

4,测试用户和组说明

版本库禁止任何匿名用户的访问,只对认证用户有效。root:配置管理管理员,对版本库有完全的管理权限。

  1. p1_admin1:project1的管理员,对project1有完全权限。
  2. p1_d1:project1的开发者,对project1的trunk有完全的权限,但是对其中的/trunk/admin目录没有任何权限。
  3. p1_t1:project1的测试者,对project1的trunk有完全的读权限,但是对其中的/trunk/admin目录没有任何权限。
  4. p2_admin1:project2的管理员,对project2有完全权限。
  5. p2_d1:project2的开发者,对project2的trunk有完全的权限,但是对其中的/trunk/admin目录没有任何权限。
  6. p2_t1:project2的测试者,对project2的trunk有完全的读权限,但是对其中的/trunk/admin目录没有任何权限。

对应的组及组的用户:

  1. p1_group_a:p1_admin1
  2. p1_group_d:p1_d1
  3. p1_group_t:p1_t1
  4. p2_group_a:p2_admin1
  5. p2_group_d:p2_d1
  6. p2_group_t:p2_t1

5,修改D:\SVNROOT\passwd文件

前面已经说过了,用户和密码文件应该是在D:\SVNROOT\passwd,所以我们为每一位用户设置权限,文件内容如下:

  1. [users]
  2. p1_admin1p1_admin1=p1_admin1
  3. p1_d1p1_d1=p1_d1
  4. p1_t1p1_t1=p1_t1
  5. p2_admin1p2_admin1=p2_admin1
  6. p2_d1p2_d1=p2_d1

p2_t1 = p2_t1为了便于验证,所有密码和用户名一致,如果你使用的是其他认证方式,这一步可能不同,但是用户名应该都是一样的。

6,配置授权,修改D:\SVNROOT\authz

  1. [groups]
  2. #定义组信息
  3. p1_group_a=p1_admin1
  4. p1_group_d=p1_d1
  5. p1_group_t=p1_t1
  6. p2_group_a=p2_admin1
  7. p2_group_d=p2_d1
  8. p2_group_t=p2_t1
  9. [/]
  10. #指定所有的版本库默认只读,root可读写
  11. *=r
  12. root=rw
  13. [project1:/]
  14. #指定对版本库project1根目录的权限
  15. @p1_group_a=rw
  16. @p1_group_d=rw
  17. @p1_group_t=r
  18. [project1:/trunk/admin]
  19. #指定对版本库project1的/trunk/admin根目录的权限,
  20. #p1_group_a读写,p1_group_d和p1_group_t没有任何权限。
  21. @p1_group_a=rw
  22. @p1_group_d=
  23. @p1_group_t=
  24. [project2:/]
  25. #指定对版本库project2根目录的权限
  26. @p2_group_a=rw
  27. @p2_group_d=rw
  28. @p2_group_t=r
  29. [project2:/trunk/admin]
  30. #指定对版本库project1的/trunk/admin根目录的权限
  31. @p2_group_a=rw
  32. @p2_group_d=
  33. @p2_group_t=

经过以上设置以后,你会发现一些有趣的事情。当使用用户“p1_d1”,检出project1的trunk时,目录是空的,好像admin目录根本不存在一样,当使用p1_d1用户浏览版本库时,能够看到admin目录,但是其中的内容却无法看到。

关于中文目录,也是没有问题的,只是注意要把authz文件转化为UTF-8格式,在我的WINXP的UltraEdit里显示的文件格式为U8-DOS,具体的做法是用UltraEdit打开authz文件,然后选择“文件->转换->ASCII转UTF-8”,然后保存。再复杂的情况也不过如此,在实际的工作中要首先规划好权限,只赋给用户最小的权限,保证以最小的配置实现最复杂的权限控制。

Subversion备份

版本控制最关键的一件事是保证数据的安全性,不能因为磁盘损坏,程序故障造成版本库无可挽回的错误,为此必须制定较完备的备份策略。在Subversion中,我们有三种备份方式:完全备份,增量备份和同步版本库。

1, 完全备份

最常见和简单的备份就是直接使用拷贝命令,将版本库目录拷贝到备份目录上,就可以了。但是这样不是很安全的方式,因为如果在拷贝时版本库发生变化,将会造成备份的结果不够准确,失去备份的作用,为此Subversion提供了“svnadmin hotcopy”命令,可以防止这种问题。还记得我们的版本库目录吗?

  1. D:\SVNROOT
  2. ├─project1
  3. │├─conf
  4. │├─dav
  5. │├─db
  6. ││├─revprops
  7. ││├─revs
  8. ││└─transactions
  9. │├─hooks
  10. │└─locks
  11. └─project2
  12. ├─conf
  13. ├─dav
  14. ├─db
  15. │├─revprops
  16. │├─revs
  17. │└─transactions
  18. ├─hooks
  19. └─locks

如果要把project1备份到d:\svnrootbak目录下,只需要运行:svnadmin hotcopy d:\svnroot\project1 d:\svnrootbak\project1。但是我们作为配置管理员,必须想办法优化这个过程,如果我们这个目录下有许多版本库,需要为每个版本库写这样一条语句备份,为此我写了下面的脚本,实现备份一个目录下的所有版本库。我们在D:\SVNROOT下创建了两个文件,simpleBackup.bat:

  1. @echo正在备份版本库%1......
  2. @%SVN_HOME%\bin\svnadminhotcopy%1%BACKUP_DIRECTORY%\%2
  3. @echo版本库%1成功备份到了%2!

这个文件仅仅是对“svnadmin hotcopy”的包装,然后是backup.bat:

  1. echooff
  2. remSubversion的安装目录
  3. setSVN_HOME="D:\Subversion"
  4. rem所有版本库的父目录
  5. setSVN_ROOT=D:\svnroot
  6. rem备份的目录
  7. setBACKUP_SVN_ROOT=D:\svnrootbak
  8. setBACKUP_DIRECTORY=%BACKUP_SVN_ROOT%\%date:~0,10%
  9. ifexist%BACKUP_DIRECTORY%gotocheckBack
  10. echo建立备份目录%BACKUP_DIRECTORY%>>%SVN_ROOT%/backup.log
  11. mkdir%BACKUP_DIRECTORY%
  12. rem验证目录是否为版本库,如果是则取出名称备份
  13. for/r%SVN_ROOT%%%Iin(.)do@ifexist"%%I\conf\svnserve.conf"%SVN_ROOT%\simpleBackup.bat"%%~fI"%%~nI
  14. gotoend
  15. :checkBack
  16. echo备份目录%BACKUP_DIRECTORY%已经存在,请清空。
  17. gotoend
  18. :end

你在使用的时候,只需要修改backup.bat开头的三个路径,将两个脚本拷贝到“SVN_ROOT”下就可以了。根据以上的配置,你只需要运行backup.bat,就可以把“SVN_ROOT”下的版本库都备份到“BACKUP_SVN_ROOT”里,并且存放在备份所在日的目录里,例如“D:\svnrootbak\2006-10-22”。

虽然这部分工作很简单,可是必须有人定时地去执行这个操作(例如每周一凌晨),为了避免发生遗忘的情况,我们可以将这个操作加入到系统的at任务当中去,例如还是上面的环境,为了安装at任务,我们运行:at 1:00 /every:M D:\svnroot\backup.bat这样在每周一凌晨1:00都会执行这个备份过程。当然备份在本机也是不安全的,你也许需要上传到别的机器,这个就要靠你自己去实现了。

2, 增量备份

尽管完全备份非常简单,但是也是有代价的,当版本库非常巨大时,经常进行完全备份是不现实的,也并不必要,但是一旦版本库在备份之间发生问题,该如何呢,这里我们就用到了增量备份。

增量备份通常要与完全备份结合使用,就像oracle数据库的归档日志,记录着每次Subversion提交的变化,然后在需要恢复时能够回到最新的可用状态。在我们这个例子中我们使用的是,svnadmin dump命令进行增量的备份,使用方法是:

  1. svnadmindumpproject1--revision15--incremental>dumpfile2

上面的命令实现了对修订版本15进行增量的备份,其中的输出文件dumpfile2只保存了修订版本15更改的内容。为了记录每次提交的结果,我们需要使用一项Subversion的特性--钩子(hook),看看我们的project1目录:

  1. ├─project1
  2. │├─conf
  3. │├─dav
  4. │├─db
  5. ││├─revprops
  6. ││├─revs
  7. ││└─transactions
  8. │├─hooks
  9. │└─locks

其中的hooks目录里存放的就是钩子脚本,我们在此处只使用post-commit钩子,这个钩子会在每次提交之后执行,为了实现我们的备份功能,我们在hooks下建立一个文件post-commit.bat,内容如下:

  1. echooff
  2. setSVN_HOME="C:\ProgramFiles\Subversion"
  3. setSVN_ROOT=D:\svnroot
  4. setUNIX_SVN_ROOT=D:/svnroot
  5. setDDELTA_BACKUP_SVN_ROOT=D:\svnrootbak\delta
  6. setLOG_FILE=%1\backup.log
  7. echobackuprevision%2>>%LOG_FILE%
  8. for/r%SVN_ROOT%%%Iin(.)doifD:/svnroot/%%~nI==%1%SVN_ROOT%\%%~nI\hooks\deltaBackup.bat%%~nI%2
  9. gotoend
  10. :end

通过这个脚本,可以实现D:\svnroot下的版本库提交时自动增量备份到D:\svnrootbak\delta(确定这个目录存在),其中使用的deltaBackup.bat其实可以放在任何地方,只是对脚本的svnadmin dump的包装,内容如下:

  1. @echo正在备份版本库%2......
  2. %SVN_HOME%\bin\svnadmindump%SVN_ROOT%\%1--incremental--revision%2>>%DELTA_BACKUP_SVN_ROOT%\%1.dump
  3. @echo版本库%2成功备份到了%3!

以上两个脚本可以直接拷贝到project2的hooks目录下,不需要修改就可以实现project2的自动备份。以上的操作已经OK了,现在需要做的是将完全备份和增量备份结合起来,也就是在完全备份后清理增量备份的结果,使之只保存完全备份后的结果。

当果真出现版本库的故障,就要求我们实现版本库的恢复操作了,这是用要使用svnadmin load命令,同时也需要上次的完全备份例如要把上次完全备份backuprepo,和之后的增量备份dumpfile:svnadmin load backuprepo < dumpfile。最后的结果,可以下载svnroot.rar,将之解压缩到d:\下,然后修改几个bat文件的SVN_HOME就可以使用了。

3, 版本库同步

Subversion 1.4增加了同步机制,可以实现一个版本库同另一个版本库的同步(但好像只是单向的),我们可以用来实现版本库的备份或镜像。

3.1. 对目标库初始化

svnsync init svn://localhost/project2 svn://localhost/project1
其中project2是目标的版本库,而project1是源版本库。其中的目标版本库必须为空,而且必须允许修订版本属性的修改,也就是在目标的版本库的hooks目录里添加一个文件pre-revprop-change.bat,内容为空即可。

3.2. 同步project2到project1

svnsync sync svn://localhost/project2
这时候你update一下你的project2的一个工作拷贝,就会发现有了project1的所有内容。如果project1又有提交,这时候project2的版本库无法看到最新的变化,还需要再运行一遍sync操作,这样才能将最新的变化同步。需要注意的是,目标版本库只能做成只读的,如果目标版本库发生了变更,则无法继续同步了。

3.3. 同步历史属性的修改

因为同步不会更新对历史属性的修改,所以svnsync还有子命令copy-revprops,可以同步某个版本的属性。

3.4. 钩子自动同步

希望在每次提交时同步,则需要在源版本库增加post-commit脚本,内容如下:

  1. echooff
  2. setSVN_HOME="D:\Subversion"
  3. %SVN_HOME%\bin\svnsyncsync--non-interactivesvn://localhost/project2

把以上内容存放为post-commit.bat,然后放到版本库project1下的hooks目录下,这样project1每次提交,都会引起project2的同步。


http://developer.51cto.com/art/201005/199661_1.htm


分享到:
评论

相关推荐

    visualSVN_server权限配置使用说明

    VisualSVN Server适用于你的团队在Windows平台上使用,可以用来安装、配置和管理Subversion Server, 其中包括了Subversion和一个管理控制台。 你可以使用Subversion client 连接到 VisualSVN Server ,也可以用...

    SVN与CVSpdf格式详细说明书

    作为一个开源的版本控制系统,Subversion 管理着随时间改变的数据。 这些数据放置在一个中央资料档案库 (repository) 中。 这个档案库很像一个普通的文件服务器, 不过它会记住每一次文件的变动。 这样你就可以把档案...

    SVN软件(服务器端+客户端+说明文档)

    如果直接使用Subversion,那么在Windows 系统上,要想让它随系统启动,就要封装SVN Server为windws service,还要通过修改配置文件来控制用户权限,另外如果要想以Web方式访问,一般还要安装配置Apache,如果是新手...

    subversion-TortoiseSVN-使用手册(CHM+HTML,中英完整版)

    5.7.2. 在Windows资源管理器中的TortoiseSVN列 5.7.3. 本地与远程状态 5.7.4. 查看差别 5.8. 版本日志对话框 5.8.1. 调用版本日志对话框 5.8.2. 获得更多信息 5.8.3. 获取更多的日志信息 5.8.4. 修改日志消息和作者 ...

    svn1.8.3所有安装文件及安装配置说明

    服务器官网下载:http://subversion.apache.org/packages.html ...1. 安装服务器Setup-Subversion-1.8.3.msi,安装路径D:/Program Files/...控制面板-windows防火墙-左侧"打开或关闭防火墙",把两个网络位置的防火墙都关掉

    源代码控制VisualSVNServer的配置和使用方法

    回答:因为如果直接使用Subversion,那么在Windows系统上,要想让它随系统启动,就要封装SVNServer为windwsservice,还要通过修改配置文件来控制用户权限,另外如果要想以Web方式【http协议】访问,一般还要安装配置...

    svn-1.4.3-setup.exe.7z

    AuthName "Subversion repositories" 用来说明何时弹出要求用户输入认证信息的认证对话框 AuthUserFile passwd 指定使用的认证密码文件 AuthzSVNAccessFile 位置Subversion版本库的访问控制文件的路径 Require ...

    Ubuntu_10.04_安装手记

    Gedit 打开Windows 下的txt文件乱码 .sh脚本文件运行 安装xnviewmp 安装CHM查看器 ecolution 配置 Rhythmbox 播放mp3的tag乱码 主题下载 备份APT缓存 启动应用程序与启动服务项 Xchat使用与操作 秀下我的桌面 超级...

    SVN快速授权脚本

    是指一组已配置好的权限配置文件和说明用于指导配置库的快速授权,应用权限模板的项目将会拥有相同的授权结构,根据版本管理工具不同授权模式分为Windows认证模式的授权模板和Subversion认证模式的授权模板两种。

    MSDN杂志 2008年新产品特刊

    &lt;br&gt;IIS 7.0: 构建具有端到端可扩展性的 Web 服务器解决方案 Mike Volodarsky 通过将“响应修改”扩展到可配置的 Web 服务器模块和 IIS 管理器的自定义管理页,向用户演示了 IIS 7.0 的可扩展模型。...

    Git权威指南PDF完整版

    3.3 在Windows 下安装和使用 Git(Cygwin篇)/ 31 3.3.1 安装 Cygwin/ 32 3.3.2 安装 Git/ 36 3.3.3 Cygwin 的配置和使用/ 37 3.3.4 Cygwin 下 Git 的中文支持/ 40 3.3.5 Cygwin 下 Git 访问 SSH 服务/ 41 3.4 ...

    Maven权威指南 很精典的学习教程,比ANT更好用

    在Microsoft Windows上安装Maven 2.3.3. 在Linux上安装Maven 2.3.4. 在FreeBSD或OpenBSD上安装Maven 2.4. 验证Maven安装 2.5. Maven安装细节 2.5.1. 用户相关配置和仓库 2.5.2. 升级Maven 2.6. 获得Maven...

    GIT中文资源

    1.4.4 在 Windows 上安装 . . . . . . . . . . . . . . . . . . . . . . 8 1.5 初次运行 Git 前的配置 . . . . . . . . . . . . . . . . . . . . . . . 9 1.5.1 用户信息 . . . . . . . . . . . . . . . . . . . . ....

Global site tag (gtag.js) - Google Analytics