Windows下SVN使用手册简明介绍(2) - 51CTO.COM

来源:百度文库 编辑:神马文学网 时间:2024/04/29 19:52:16
  • Windows下SVN使用手册简明介绍(2)

  • http://developer.51cto.com  2010-05-26 12:45  佚名    我要评论()
    本文和大家一起学习一下SVN使用手册,主要包括客户端使用,SVN命令行和版本库的备份等内容,希望通过本文学习的大家对Windows下SVN使用更加熟练。
     
    2.增量备份
    SVN使用手册介绍一下增量备份。尽管完全备份非常简单,但也是有代价的。当版本库非常巨大时,经常进行完全备份是不现实,也是不必要的。但是一旦版本库在备份之间发生问题,该怎么办呢?这里我们就用到了增量备份。增量备份通常要与完全备份结合使用,就像Oracle数据库的归档日志,记录着每次Subversion提交的变化,然后在需要恢复时能够回到最新的可用状态。在我们这个例子中我们使用的是svnadmindump命令进行增量的备份。使用方法是:svnadmindumpproject1--revision15--incremental>dumpfile2
    上面的命令实现了对修订版本15进行增量的备份,其中的输出文件dumpfile2只保存了修订版本15更改的内容。
    为了记录每次提交的结果,我们需要使用一项Subversion的特性——钩子(hook)。
    hooks目录里存放的就是钩子脚本。我们在此处只使用post-commit钩子,这个钩子会在每次提交之后执行。为了实现我们的备份功能,我们在hooks下建立一个文件post-commit.bat,内容如下:
    echooff
    setSVN_HOME="C:ProgramFilesSubversion"
    setSVN_ROOT=D:svnroot
    setUNIX_SVN_ROOT=D:/svnroot
    setDELTA_BACKUP_SVN_ROOT=D:svnrootbakdelta
    setLOG_FILE=%1backup.log
    echobackuprevision%2>>%LOG_FILE%
    for/r%SVN_ROOT%%%Iin(.)doifD:/svnroot/%%~nI==%1%SVN_ROOT%%%~nIhooksdeltaBackup.bat%%~nI%2(这里没有看懂,请高手指点?)
    gotoend
    :end
    通过这个脚本,可以实现D:svnroot下的版本库提交时自动增量备份到D:svnrootbakdelta(确定这个目录存在),其中使用的deltaBackup.bat其实可以放在任何地方,只是对脚本的svnadmindump的包装,内容如下:
    @echo正在备份版本库%2......
    %SVN_HOME%binsvnadmindump%SVN_ROOT%%1--incremental--revision%2>>%DELTA_BACKUP_SVN_ROOT%%1.dump
    @echo版本库%2成功备份到了%1!
    以上两个脚本可以直接拷贝到project2的hooks目录下,不需要修改就可以实现project2的自动备份。
    以上的操作已经OK了,现在需要做的是将完全备份和增量备份结合起来,也就是在完全备份后清理增量备份的结果,使之只保存完全备份后的结果。
    当果真出现版本库的故障,就要求我们实现版本库的恢复操作了。这时要使用svnadminload命令,同时也需要上次的完全备份。例如要把上次完全备份backuprepo,和之后的增量备份dumpfile:
    svnadminloadbackuprepo最后的结果可以下载svnroot.rar,将之解压缩到d:下,然后修改几个bat文件的SVN_HOME就可以使用了。
    3.版本库同步
    SVN使用手册中版本库同步问题。Subversion1.4增加了同步机制,可以实现一个版本库同另一个版本库的同步(但好像只是单向的),我们可以用来实现版本库的备份或镜像。
    3.1对目标库初始化
    svnsyncinitsvn://localhost/project2svn://localhost/project1
    其中project2是目标的版本库,而project1是源版本库。其中的目标版本库必须为空,而且必须允许修订版本属性的修改,也就是在目标的版本库的hooks目录里添加一个文件pre-revprop-change.bat,内容为空即可。
    3.2同步project2到project1
    svnsyncsyncsvn://localhost/project2
    这时候你update一下你的project2的一个工作拷贝,就会发现有了project1的所有内容。如果project1又有提交,这时候project2的版本库无法看到最新的变化,还需要再运行一遍sync操作,这样才能将最新的变化同步。需要注意的是,目标版本库只能做成只读的,如果目标版本库发生了变更,则无法继续同步了。
    3.3同步历史属性的修改
    因为同步不会更新对历史属性的修改,所以svnsync还有子命令copy-revprops,可以同步某个版本的属性。
    3.4钩子自动同步
    希望在每次提交时同步,则需要在源版本库增加post-commit脚本,内容如下:
    echooff
    setSVN_HOME="D:Subversion"
    %SVN_HOME%binsvnsyncsync--non-interactivesvn://localhost/project2
    把以上内容存放为post-commit.bat,然后放到版本库project1下的hooks目录下,这样project1每次提交,都会引起project2的同步。本节介绍SVN使用手册完毕,请关注本节其他相关报道。