SVN完全备份,增量备份,库同步

1, 完全备份

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

还记得我们的版本库目录吗?

D:/SVNROOT
├─project1
│<wbr> ├─conf<br>│<wbr> ├─dav<br>│<wbr> ├─db<br>│<wbr> │<wbr> ├─revprops<br>│<wbr> │<wbr> ├─revs<br>│<wbr> │<wbr> └─transactions<br>│<wbr> ├─hooks<br>│<wbr> └─locks<br>└─project2<br><wbr><wbr><wbr> ├─conf<br><wbr><wbr><wbr> ├─dav<br><wbr><wbr><wbr> ├─db<br><wbr><wbr><wbr> │<wbr> ├─revprops<br><wbr><wbr><wbr> │<wbr> ├─revs<br><wbr><wbr><wbr> │<wbr> └─transactions<br><wbr><wbr><wbr> ├─hooks<br><wbr><wbr><wbr> └─locks<br><wbr><wbr><wbr><br></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr>

如果要把project1备份到d:/svnrootbak目录下,只需要运行:

svnadmin hotcopy d:/svnroot/project1 d:/svnrootbak/project1


<wbr><h3>2, 增量备份</h3> <p>尽管完全备份非常简单,但是也是有代价的,当版本库非常巨大时,经常进行完全备份是不现实的,也并不必要,但是一旦版本库在备份之间发生问题,该如何呢,这里我们就用到了增量备份。</p> <p>增量备份通常要与完全备份结合使用,就像oracle数据库的归档日志,记录着每次Subversion提交的变化,然后在需要恢复时能够回到最新的可用状态。在我们这个例子中我们使用的是,svnadmin dump命令进行增量的备份,使用方法是:</p> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"> <p>svnadmin dump<wbr>project1<wbr>--revision 15 --incremental &gt; dumpfile2</wbr></wbr></p> </blockquote> <p>上面的命令实现了对修订版本15进行增量的备份,其中的输出文件dumpfile2只保存了修订版本15更改的内容。</p> <p>为了记录每次提交的结果,我们需要使用一项Subversion的特性--<a href="http://www.subversion.org.cn/svnbook/1.1/svn-ch-5-sect-2.html#svn-ch-5-sect-2.1"><u><font color="#800080">钩子(hook)</font></u></a>,看看我们的project1目录:</p> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"> <p>├─project1<br>│<wbr> ├─conf<br>│<wbr> ├─dav<br>│<wbr> ├─db<br>│<wbr> │<wbr> ├─revprops<br>│<wbr> │<wbr> ├─revs<br>│<wbr> │<wbr> └─transactions<br>│<wbr> ├─hooks<br>│<wbr> └─locks</wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></wbr></p> </blockquote> <p>其中的hooks目录里存放的就是钩子脚本,我们在此处只使用post-commit钩子,这个钩子会在每次提交之后执行,为了实现我们的备份功能,我们在hooks下建立一个文件post-commit.bat,内容如下:</p> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"> <address>echo off<br>set SVN_HOME="C:/Program Files/Subversion"<br>set SVN_ROOT=D:/svnroot<br>set UNIX_SVN_ROOT=D:/svnroot<br>set DELTA_BACKUP_SVN_ROOT=D:/svnrootbak/delta</address> <address>set LOG_FILE=%1/backup.log<br>echo backup revision %2 &gt;&gt; %LOG_FILE%</address> <address>for /r %SVN_ROOT% %%I in (.) do if D:/svnroot/%%~nI == %1 %SVN_ROOT%/%%~nI/hooks/deltaBackup.bat %%~nI %2<br>goto end</address> <address>:end</address> </blockquote> <p>通过这个脚本,可以实现D:/svnroot下的版本库提交时自动增量备份到D:/svnrootbak/delta(确定这个目录存在),其中使用的deltaBackup.bat其实可以放在任何地方,只是对脚本的svnadmin dump的包装,内容如下:</p> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"> <p>@echo 正在备份版本库%2......<br>%SVN_HOME%/bin/svnadmin dump %SVN_ROOT%/%1 --incremental --revision %2 &gt;&gt; %DELTA_BACKUP_SVN_ROOT%/%1.dump<br>@echo 版本库%2成功备份到了%3!</p> </blockquote> <p>以上两个脚本可以直接拷贝到project2的hooks目录下,不需要修改就可以实现project2的自动备份。</p> <p>以上的操作已经OK了,现在需要做的是将完全备份和增量备份结合起来,也就是在完全备份后清理增量备份的结果,使之只保存完全备份后的结果。</p> <p>当果真出现版本库的故障,就要求我们实现版本库的恢复操作了,这是用要使用svnadmin load命令,同时也需要上次的完全备份例如要把上次完全备份backuprepo,和之后的增量备份dumpfile:</p> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"> <p>svnadmin load<wbr>backuprepo &lt; dumpfile</wbr></p> </blockquote> <p>最后的结果,可以下载<a href="http://www.subversion.org.cn/images/stories/svnroot.rar"><u><font color="#b82165">svnroot.rar</font></u></a>,将之解压缩到d:/下,然后修改几个bat文件的SVN_HOME就可以使用了。</p> <h3>3, 版本库同步</h3> <p>Subversion 1.4增加了同步机制,可以实现一个版本库同另一个版本库的同步(但好像只是单向的),我们可以用来实现版本库的备份或镜像。</p> <h5>3.1. 对目标库初始化</h5> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"><pre>svnsync init svn:<font face="Courier New"><span style="FONT-STYLE: italic; COLOR: rgb(128,128,128)">//localhost/project2 svn://localhost/project1 </span><br></font><wbr></wbr></pre></blockquote> <p><font size="2">其中project2是目标的版本库,而project1是源版本库。其中的目标版本库必须为空,而且必须允许修订版本属性的修改,也就是在目标的版本库的hooks目录里添加一个文件pre-revprop-change.bat,内容为空即可。</font></p> <h5>3.2. 同步project2到project1</h5> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"><pre>svnsync sync svn:<font face="Courier New"><span style="FONT-STYLE: italic; COLOR: rgb(128,128,128)">//localhost/project2 </span><br></font><wbr></wbr></pre></blockquote> <p>这时候你update一下你的project2的一个工作拷贝,就会发现有了project1的所有内容。如果project1又有提交,这时候 project2的版本库无法看到最新的变化,还需要再运行一遍sync操作,这样才能将最新的变化同步。需要注意的是,目标版本库只能做成只读的,如果目标版本库发生了变更,则无法继续同步了。</p> <h5>3.3. 同步历史属性的修改</h5> <p>因为同步不会更新对历史属性的修改,所以svnsync还有子命令copy-revprops,可以同步某个版本的属性。</p> <h5>3.4. 钩子自动同步</h5> <p>希望在每次提交时同步,则需要在源版本库增加post-commit脚本,内容如下:</p> <blockquote style="MARGIN-RIGHT: 0px" dir="ltr"><pre><a href="http://www.php.net/echo"><span style="COLOR: rgb(0,0,102)"><font face="Courier New"><u>echo</u></font></span></a> off<br>set SVN_HOME=<font face="Courier New"><span style="COLOR: rgb(255,0,0)">"D:<span style="COLOR: rgb(0,0,153); FONT-WEIGHT: bold"><font color="#ff3300">/S</font></span>ubversion"</span><br>%SVN_HOME%/bin/svnsync sync --non-interactive svn:<span style="FONT-STYLE: italic; COLOR: rgb(128,128,128)">//localhost/project2 </span><br></font><wbr></wbr></pre></blockquote> <p>把以上内容存放为post-commit.bat,然后放到版本库project1下的hooks目录下,这样project1每次提交,都会引起project2的同步。</p> </wbr>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值