Subversion備份 |
作者: rocksun? ? 2006-10-26 作者:Rock Sun, Subversion中文站。 如有轉發請注明出處:http://www.subversion.org.cn/ind ... ;id=85&Itemid=9 版本控制最關鍵的一件事是保證數據的安全性,不能因為磁盤損壞,程序故障造成版本庫無可挽回的錯誤,為此必須制定較完備的備份策略。在Subversion中,我們有三種備份方式:完全備份,增量備份和同步版本庫。 1, 完全備份 最常見和簡單的備份就是直接使用拷貝命令,將版本庫目錄拷貝到備份目錄上,就可以了。但是這樣不是很安全的方式,因為如果在拷貝時版本庫發生變化,將會造成備份的結果不夠準確,失去備份的作用,為此Subversion提供了“svnadmin hotcopy”命令,可以防止這種問題。 還記得我們的版本庫目錄嗎? ? ? D:\SVNROOT ? ? ├─project1 ? ? │??├─conf ? ? │??├─dav ? ? │??├─db ? ? │??│??├─revprops ? ? │??│??├─revs ? ? │??│??└─transactions ? ? │??├─hooks ? ? │??└─locks ? ? └─project2 ? ?? ???├─conf ? ?? ???├─dav ? ?? ???├─db ? ?? ???│??├─revprops ? ?? ???│??├─revs ? ?? ???│??└─transactions ? ?? ???├─hooks ? ?? ???└─locks ? ?? ? 我們在D:\SVNROOT下創建了兩個文件,simpleBackup.bat: ? ? @echo 正在備份版本庫%1...... ? ? @%SVN_HOME%\bin\svnadmin hotcopy %1 %BACKUP_DIRECTORY%\%2 ? ? @echo 版本庫%1成功備份到了%2! 這個文件僅僅是對“svnadmin hotcopy”的包裝,然后是backup.bat: ? ? echo off ? ? rem Subversion的安裝目錄 ? ? set SVN_HOME="D:\Subversion" ? ? rem 所有版本庫的父目錄 ? ? set SVN_ROOT=D:\svnroot ? ? rem 備份的目錄 ? ? set BACKUP_SVN_ROOT=D:\svnrootbak ? ? set BACKUP_DIRECTORY=%BACKUP_SVN_ROOT%\%date:~0,10% ? ? if exist %BACKUP_DIRECTORY% goto checkBack ? ? echo 建立備份目錄%BACKUP_DIRECTORY%>>%SVN_ROOT%/backup.log ? ? mkdir %BACKUP_DIRECTORY% ? ? for /r %SVN_ROOT% %%I in (.) do @if exist "%%I\conf\svnserve.conf" %SVN_ROOT%\simpleBackup.bat "%%~fI" %%~nI ? ? goto end ? ? :checkBack ? ? echo 備份目錄%BACKUP_DIRECTORY%已經存在,請清空。 ? ? goto end ? ? :end 根據以上的配置,你只需要運行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提交的變化,然后在需要恢復時能夠回到最新的可用狀態。 為了記錄每次提交的結果,我們需要使用一項Subversion的特性--鉤子(hook),看看我們的project1目錄: ? ? ├─project1 ? ? │??├─conf ? ? │??├─dav ? ? │??├─db ? ? │??│??├─revprops ? ? │??│??├─revs ? ? │??│??└─transactions ? ? │??├─hooks ? ? │??└─locks 其中的hooks目錄里存放的就是鉤子腳本,我們在此處只使用post-commit鉤子,這個鉤子會在每次提交之后執行,為了實現我們的備份功能,我們在hooks下建立一個文件post-commit.bat,內容如下: ? ? echo off ? ? set SVN_HOME="C:\Program Files\Subversion" ? ? set SVN_ROOT=D:\svnroot ? ? set UNIX_SVN_ROOT=D:/svnroot ? ? set DELTA_BACKUP_SVN_ROOT=D:\svnrootbak\delta ? ? set LOG_FILE=%1\backup.log ? ? echo backup revision %2 >> %LOG_FILE% ? ? for /r %SVN_ROOT% %%I in (.) do if D:/svnroot/%%~nI == %1 %SVN_ROOT%\%%~nI\hooks\deltaBackup.bat %%~nI %2 ? ? goto end ? ? :end 通過這個腳本,可以實現D:\svnroot下的版本庫提交時自動增量備份到D:\svnrootbak\delta(確定這個目錄存在),其中使用的deltaBackup.bat其實可以放在任何地方,只是對腳本的svnadmin dump的包裝,內容如下: ? ? @echo 正在備份版本庫%2...... ? ? %SVN_HOME%\bin\svnadmin dump %SVN_ROOT%\%1 --incremental --revision %2 >> %DELTA_BACKUP_SVN_ROOT%\%1.dump ? ? @echo 版本庫%2成功備份到了%3! 以上兩個腳本可以直接拷貝到project2的hooks目錄下,不需要修改就可以實現project2的自動備份。 以上的操作已經OK了,現在需要做的是將完全備份和增量備份結合起來,也就是在完全備份后清理增量備份的結果,使只保存完全備份后的結果。 最后的結果,可以下載附件,將之解壓縮到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腳本,內容如下: echo off set SVN_HOME="D:\Subversion" %SVN_HOME%\bin\svnsync sync??--non-interactive svn://localhost/project2 把以上內容存放為post-commit.bat,然后放到版本庫project1下的hooks目錄下,這樣project1每次提交,都會引起project12的同步。 |
8 評論
好!
|
版本庫同步 3.1-3.3都可以實現。 但是"3.4. 鉤子自動同步"不行。 我的post-commit.bat是這樣的: echo off set SVN_HOME="C:\Program Files\Subversion" %SVN_HOME%\bin\svnsync sync --non-interactive http://127.0.0.1/svn/MyData2 這是什么原因呢?
|
你單獨執行一下post-commit.bat,看看報告什么錯誤。
|
我在.bat文件中加了pause。 執行的情況是 F:\XMDKSVN\MyData\hooks>echo off 請按任意鍵繼續. . . [ 本帖最后由 Jeffrey 于 2006-11-10 11:51 編輯 ]
|
嗯,應該沒問題把?
|
先謝謝rocksun。 嗯。我單打開post-commit.bat,如果MyData有變化了,MyData@是可以和它同步的。但就是在提交時,兩個沒辦法同步。 這是怎么回事呢。
|
應該沒問題吧? post-commit和提交是完全獨立的,不會互相影響
|
我還是不明白耶。
|