日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Windows下Subversion管理配置詳細(xì)說明

從Subversion1.4開始,Subversion本身就集成Windows服務(wù)的工具。我們不必像以前一樣,必須依賴于svnservice或其他工具。

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),泗水企業(yè)網(wǎng)站建設(shè),泗水品牌網(wǎng)站建設(shè),網(wǎng)站定制,泗水網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷,網(wǎng)絡(luò)優(yōu)化,泗水網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。

1,安裝svnservice

在Windows NT中(包括Windows XP, Windows 2000, Windows 2003 Server)本身包含了一個(gè)安裝服務(wù)的工具,叫做"Service Control",也就是sc.exe。例如我的Subversion安裝在"D:\Subversion",版本庫(kù)在"D:\svnroot",而我希望對(duì)應(yīng)的Subversion服務(wù)名為svnservice,安裝這個(gè)svn服務(wù)的命令就可以這樣寫:

 
 
 
  1. sc create svnservice  
  2. binpath= "D:\Subversion\bin\svnserve.exe --service -r D:\svnroot" 
  3. displayname= "SVNService" 
  4. depend= Tcpip  

請(qǐng)注意,因?yàn)楸阌诓炜?,上面的命令分為多行,但在?shí)際執(zhí)行時(shí)應(yīng)該在一行里。另外,在以前啟動(dòng)svnserve時(shí)會(huì)使用"-d"選項(xiàng),也就是守護(hù)進(jìn)程模式,在這里不能使用,會(huì)導(dǎo)致服務(wù)無法啟動(dòng)。同樣,"-i"和"-t"選項(xiàng)也不能使用。在命令行窗口執(zhí)行完這個(gè)命令之后,服務(wù)還沒有啟動(dòng),你可以繼續(xù)運(yùn)行"net start svnservice"啟動(dòng)這個(gè)服務(wù),然后使用"net stop svnservice"停止服務(wù)。

另外還有兩點(diǎn)需要小心處理。首先,如果路徑中包括空格,一定要用“\”處理“"”號(hào),例如上面的例子中如果svnserve.exe在“c:\program files\subversion\”中,則命令應(yīng)該寫為“binpath= "\"c:\program files\subversion\bin\svnserve.exe\"”(“”中的內(nèi)容),整個(gè)命令如下,紅色部分是改變部分。

 
 
 
  1. sc create svnservice  
  2. binpath= "\"D:\program files\Subversion\bin\svnserve.exe\" --service -r D:\svnroot"  
  3. displayname= "SVNService" 
  4. depend= Tcpip  

其次,sc對(duì)選項(xiàng)的格式還有要求,例如“depend= Tcpip”不能寫為“depend = Tcpip”或“depend=Tcpip”,也就是“=”前不能有空各,而后面必須有空格。

2,刪除服務(wù)

如果服務(wù)安裝的有問題,你可能需要?jiǎng)h除服務(wù)。要?jiǎng)h除前面添加的服務(wù),只需要運(yùn)行"net start svnservice","svnservice"就是我們創(chuàng)建服務(wù)時(shí)使用的名字。

3,配置服務(wù)是自動(dòng)啟動(dòng)

默認(rèn)情況下安裝的服務(wù)不會(huì)隨Windows的啟動(dòng)而啟動(dòng),為了使svn服務(wù)能夠隨Windows啟動(dòng)而啟動(dòng),需要修改一下"sc create"命令(首先要?jiǎng)h除),增加"start= auto"選項(xiàng):

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

當(dāng)然你也可以使用圖形化的工具修改服務(wù)的屬性,你可以在“開始->運(yùn)行...”中執(zhí)行"services.msc",然后在界面中修改。

Subversion的權(quán)限控制

1,認(rèn)證(Authentication)和授權(quán)(Authorization)

這兩個(gè)術(shù)語(yǔ)經(jīng)常一起出現(xiàn)。其中認(rèn)證的意思就是鑒別用戶的身份,最常見的方式就是使用用戶名和密碼,授權(quán)就是判斷用戶是否具備某種操作的權(quán)限,在Subversion里提供了“authz-db”文件,實(shí)現(xiàn)了以路徑為基礎(chǔ)的授權(quán),也就是判斷用戶是否有操作對(duì)應(yīng)路徑的權(quán)限,在Subversion 1.3之后,svnserve和Apache一樣都可以使用“authz-db”文件。

2. svnserve下的配置文件

因?yàn)楸疚氖且詓vnserve為例的,所以先介紹一下版本庫(kù)目錄的結(jié)構(gòu):

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

其中conf下面有三個(gè)文件:

 
 
 
  1. authz  
  2. passwd  
  3. svnserve.conf  

其中的“svnserve.conf”是這個(gè)版本庫(kù)的配置文件,當(dāng)使用svnserve時(shí),這個(gè)配置文件決定了使用什么認(rèn)證和授權(quán)文件:

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

上面的配置說明使用“svnserve.conf”同目錄的passwd和authz,其中的password-db指定了用戶密碼文件,authz-db是我們的授權(quán)文件,也就是我們本文主要介紹的文件。注意:使用Apache作為服務(wù)器時(shí),根本就不會(huì)參考“svnserve.conf”文件的內(nèi)容,而是會(huì)參考Apache的配置。

3,基于svnserve的版本庫(kù)文件布局

使用svnserve時(shí),為了管理的方便,應(yīng)該使用相同的認(rèn)證和授權(quán)文件,所以應(yīng)該讓所有版本庫(kù)的配置文件svnserve.conf指向同一個(gè)password-db和authz-db文件。下面是一個(gè)多版本庫(kù)的目錄:

 
 
 
  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下有兩個(gè)目錄project1和project2,都已經(jīng)創(chuàng)建了版本庫(kù),所以我們修改每個(gè)conf目錄下的svnserve.conf,使之指向同一個(gè)password-db和authz-db文件。

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

authz-db = ..\..\authz這樣,D:\SVNROOT\passwd和D:\SVNROOT\authz就控制了所有版本庫(kù)的svnserve訪問。另外在后面的操作中要關(guān)閉匿名訪問,應(yīng)該去掉“anon-access = none”前的“#”號(hào),保證只有認(rèn)證用戶可以訪問。

注意:還有一點(diǎn)需要注意,那就是svnserve的“realm”的值,在上面的設(shè)置下,應(yīng)該保證所有的版本庫(kù)使用相同的realm值,這樣,對(duì)版本庫(kù)的密碼緩存可以在多個(gè)版本庫(kù)之間共享,更多細(xì)節(jié)見客戶端憑證緩存。

4,測(cè)試用戶和組說明

版本庫(kù)禁止任何匿名用戶的訪問,只對(duì)認(rèn)證用戶有效。root:配置管理管理員,對(duì)版本庫(kù)有完全的管理權(quán)限。

 
 
 
  1. p1_admin1:project1的管理員,對(duì)project1有完全權(quán)限。  
  2. p1_d1:project1的開發(fā)者,對(duì)project1的trunk有完全的權(quán)限,但是對(duì)其中的/trunk/admin目錄沒有任何權(quán)限。  
  3. p1_t1:project1的測(cè)試者,對(duì)project1的trunk有完全的讀權(quán)限,但是對(duì)其中的/trunk/admin目錄沒有任何權(quán)限。  
  4.  
  5. p2_admin1:project2的管理員,對(duì)project2有完全權(quán)限。  
  6. p2_d1:project2的開發(fā)者,對(duì)project2的trunk有完全的權(quán)限,但是對(duì)其中的/trunk/admin目錄沒有任何權(quán)限。  
  7. p2_t1:project2的測(cè)試者,對(duì)project2的trunk有完全的讀權(quán)限,但是對(duì)其中的/trunk/admin目錄沒有任何權(quán)限。 

對(duì)應(yīng)的組及組的用戶:

 
 
 
  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文件

前面已經(jīng)說過了,用戶和密碼文件應(yīng)該是在D:\SVNROOT\passwd,所以我們?yōu)槊恳晃挥脩粼O(shè)置權(quán)限,文件內(nèi)容如下:

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

p2_t1 = p2_t1為了便于驗(yàn)證,所有密碼和用戶名一致,如果你使用的是其他認(rèn)證方式,這一步可能不同,但是用戶名應(yīng)該都是一樣的。

6,配置授權(quán),修改D:\SVNROOT\authz

 
 
 
  1. [groups]  
  2. # 定義組信息  
  3.  
  4. p1_group_a = p1_admin1 
  5. p1_group_d = p1_d1 
  6. p1_group_t = p1_t1 
  7.  
  8. p2_group_a = p2_admin1 
  9. p2_group_d = p2_d1 
  10. p2_group_t = p2_t1 
  11.  
  12. [/]  
  13. # 指定所有的版本庫(kù)默認(rèn)只讀,root可讀寫  
  14. * = r  
  15. root = rw 
  16.  
  17. [project1:/]  
  18. # 指定對(duì)版本庫(kù)project1根目錄的權(quán)限  
  19. @p1_group_a = rw 
  20. @p1_group_d = rw 
  21. @p1_group_t = r  
  22.  
  23. [project1:/trunk/admin]  
  24. # 指定對(duì)版本庫(kù)project1的/trunk/admin根目錄的權(quán)限,  
  25. # p1_group_a讀寫,p1_group_d和p1_group_t沒有任何權(quán)限。  
  26. @p1_group_a = rw 
  27. @p1_group_d =   
  28. @p1_group_t =   
  29.  
  30. [project2:/]  
  31. # 指定對(duì)版本庫(kù)project2根目錄的權(quán)限  
  32. @p2_group_a = rw 
  33. @p2_group_d = rw 
  34. @p2_group_t = r  
  35.  
  36. [project2:/trunk/admin]  
  37. # 指定對(duì)版本庫(kù)project1的/trunk/admin根目錄的權(quán)限  
  38. @p2_group_a = rw 
  39. @p2_group_d =   
  40. @p2_group_t =   

經(jīng)過以上設(shè)置以后,你會(huì)發(fā)現(xiàn)一些有趣的事情。當(dāng)使用用戶“p1_d1”,檢出project1的trunk時(shí),目錄是空的,好像admin目錄根本不存在一樣,當(dāng)使用p1_d1用戶瀏覽版本庫(kù)時(shí),能夠看到admin目錄,但是其中的內(nèi)容卻無法看到。

關(guān)于中文目錄,也是沒有問題的,只是注意要把a(bǔ)uthz文件轉(zhuǎn)化為UTF-8格式,在我的WINXP的UltraEdit里顯示的文件格式為U8-DOS,具體的做法是用UltraEdit打開authz文件,然后選擇“文件->轉(zhuǎn)換->ASCII轉(zhuǎn)UTF-8”,然后保存。再?gòu)?fù)雜的情況也不過如此,在實(shí)際的工作中要首先規(guī)劃好權(quán)限,只賦給用戶最小的權(quán)限,保證以最小的配置實(shí)現(xiàn)最復(fù)雜的權(quán)限控制。

#p#

Subversion備份

版本控制最關(guān)鍵的一件事是保證數(shù)據(jù)的安全性,不能因?yàn)榇疟P損壞,程序故障造成版本庫(kù)無可挽回的錯(cuò)誤,為此必須制定較完備的備份策略。在Subversion中,我們有三種備份方式:完全備份,增量備份和同步版本庫(kù)。

1, 完全備份

最常見和簡(jiǎn)單的備份就是直接使用拷貝命令,將版本庫(kù)目錄拷貝到備份目錄上,就可以了。但是這樣不是很安全的方式,因?yàn)槿绻诳截悤r(shí)版本庫(kù)發(fā)生變化,將會(huì)造成備份的結(jié)果不夠準(zhǔn)確,失去備份的作用,為此Subversion提供了“svnadmin hotcopy”命令,可以防止這種問題。還記得我們的版本庫(kù)目錄嗎?

 
 
 
  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目錄下,只需要運(yùn)行:svnadmin hotcopy d:\svnroot\project1 d:\svnrootbak\project1。但是我們作為配置管理員,必須想辦法優(yōu)化這個(gè)過程,如果我們這個(gè)目錄下有許多版本庫(kù),需要為每個(gè)版本庫(kù)寫這樣一條語(yǔ)句備份,為此我寫了下面的腳本,實(shí)現(xiàn)備份一個(gè)目錄下的所有版本庫(kù)。我們?cè)贒:\SVNROOT下創(chuàng)建了兩個(gè)文件,simpleBackup.bat:

 
 
 
  1. @echo 正在備份版本庫(kù)%1......  
  2. @%SVN_HOME%\bin\svnadmin hotcopy %1 %BACKUP_DIRECTORY%\%2  
  3. @echo 版本庫(kù)%1成功備份到了%2! 

這個(gè)文件僅僅是對(duì)“svnadmin hotcopy”的包裝,然后是backup.bat:

 
 
 
  1. echo off  
  2.  
  3. rem Subversion的安裝目錄  
  4. set SVN_HOME="D:\Subversion" 
  5.  
  6. rem 所有版本庫(kù)的父目錄  
  7. set SVN_ROOT=D:\svnroot  
  8.  
  9. rem 備份的目錄  
  10. set BACKUP_SVN_ROOT=D:\svnrootbak  
  11.  
  12. set BACKUP_DIRECTORY=%BACKUP_SVN_ROOT%\%date:~0,10%  
  13. if exist %BACKUP_DIRECTORY% goto checkBack  
  14. echo 建立備份目錄%BACKUP_DIRECTORY%>>%SVN_ROOT%/backup.log  
  15.  
  16. mkdir %BACKUP_DIRECTORY%  
  17.  
  18. rem 驗(yàn)證目錄是否為版本庫(kù),如果是則取出名稱備份  
  19. for /r %SVN_ROOT% %%I in (.) do @if exist "%%I\conf\svnserve.conf" %SVN_ROOT%\simpleBackup.bat "%%~fI" %%~nI  
  20. goto end  
  21.  
  22. :checkBack  
  23. echo 備份目錄%BACKUP_DIRECTORY%已經(jīng)存在,請(qǐng)清空。  
  24. goto end  
  25.  
  26. :end  

你在使用的時(shí)候,只需要修改backup.bat開頭的三個(gè)路徑,將兩個(gè)腳本拷貝到“SVN_ROOT”下就可以了。根據(jù)以上的配置,你只需要運(yùn)行backup.bat,就可以把“SVN_ROOT”下的版本庫(kù)都備份到“BACKUP_SVN_ROOT”里,并且存放在備份所在日的目錄里,例如“D:\svnrootbak\2006-10-22”。

雖然這部分工作很簡(jiǎn)單,可是必須有人定時(shí)地去執(zhí)行這個(gè)操作(例如每周一凌晨),為了避免發(fā)生遺忘的情況,我們可以將這個(gè)操作加入到系統(tǒng)的at任務(wù)當(dāng)中去,例如還是上面的環(huán)境,為了安裝at任務(wù),我們運(yùn)行:at 1:00 /every:M D:\svnroot\backup.bat這樣在每周一凌晨1:00都會(huì)執(zhí)行這個(gè)備份過程。當(dāng)然備份在本機(jī)也是不安全的,你也許需要上傳到別的機(jī)器,這個(gè)就要靠你自己去實(shí)現(xiàn)了。

2, 增量備份

盡管完全備份非常簡(jiǎn)單,但是也是有代價(jià)的,當(dāng)版本庫(kù)非常巨大時(shí),經(jīng)常進(jìn)行完全備份是不現(xiàn)實(shí)的,也并不必要,但是一旦版本庫(kù)在備份之間發(fā)生問題,該如何呢,這里我們就用到了增量備份。

增量備份通常要與完全備份結(jié)合使用,就像oracle數(shù)據(jù)庫(kù)的歸檔日志,記錄著每次Subversion提交的變化,然后在需要恢復(fù)時(shí)能夠回到***的可用狀態(tài)。在我們這個(gè)例子中我們使用的是,svnadmin dump命令進(jìn)行增量的備份,使用方法是:

 
 
 
  1. svnadmin dump project1 --revision 15 --incremental > dumpfile2 
  2.  

上面的命令實(shí)現(xiàn)了對(duì)修訂版本15進(jìn)行增量的備份,其中的輸出文件dumpfile2只保存了修訂版本15更改的內(nèi)容。為了記錄每次提交的結(jié)果,我們需要使用一項(xiàng)Subversion的特性--鉤子(hook),看看我們的project1目錄:

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

其中的hooks目錄里存放的就是鉤子腳本,我們?cè)诖颂幹皇褂胮ost-commit鉤子,這個(gè)鉤子會(huì)在每次提交之后執(zhí)行,為了實(shí)現(xiàn)我們的備份功能,我們?cè)趆ooks下建立一個(gè)文件post-commit.bat,內(nèi)容如下:

 
 
 
  1. echo off  
  2. set SVN_HOME="C:\Program Files\Subversion" 
  3. set SVN_ROOT=D:\svnroot  
  4. set UNIX_SVN_ROOT=D:/svnroot  
  5. set DDELTA_BACKUP_SVN_ROOT=D:\svnrootbak\delta  
  6. set LOG_FILE=%1\backup.log  
  7. echo backup revision %2 >> %LOG_FILE%  
  8. for /r %SVN_ROOT% %%I in (.) do if D:/svnroot/%%~nI == %1 %SVN_ROOT%\%%~nI\hooks\deltaBackup.bat %%~nI %2  
  9. goto end  
  10. :end  

通過這個(gè)腳本,可以實(shí)現(xiàn)D:\svnroot下的版本庫(kù)提交時(shí)自動(dòng)增量備份到D:\svnrootbak\delta(確定這個(gè)目錄存在),其中使用的deltaBackup.bat其實(shí)可以放在任何地方,只是對(duì)腳本的svnadmin dump的包裝,內(nèi)容如下:

 
 
 
  1. @echo 正在備份版本庫(kù)%2......  
  2. %SVN_HOME%\bin\svnadmin dump %SVN_ROOT%\%1 --incremental --revision %2 >> %DELTA_BACKUP_SVN_ROOT%\%1.dump  
  3. @echo 版本庫(kù)%2成功備份到了%3! 

以上兩個(gè)腳本可以直接拷貝到project2的hooks目錄下,不需要修改就可以實(shí)現(xiàn)project2的自動(dòng)備份。以上的操作已經(jīng)OK了,現(xiàn)在需要做的是將完全備份和增量備份結(jié)合起來,也就是在完全備份后清理增量備份的結(jié)果,使之只保存完全備份后的結(jié)果。

當(dāng)果真出現(xiàn)版本庫(kù)的故障,就要求我們實(shí)現(xiàn)版本庫(kù)的恢復(fù)操作了,這是用要使用svnadmin load命令,同時(shí)也需要上次的完全備份例如要把上次完全備份backuprepo,和之后的增量備份dumpfile:svnadmin load backuprepo < dumpfile。***的結(jié)果,可以下載svnroot.rar,將之解壓縮到d:\下,然后修改幾個(gè)bat文件的SVN_HOME就可以使用了。

3, 版本庫(kù)同步

Subversion 1.4增加了同步機(jī)制,可以實(shí)現(xiàn)一個(gè)版本庫(kù)同另一個(gè)版本庫(kù)的同步(但好像只是單向的),我們可以用來實(shí)現(xiàn)版本庫(kù)的備份或鏡像。

3.1. 對(duì)目標(biāo)庫(kù)初始化

svnsync init svn://localhost/project2 svn://localhost/project1
其中project2是目標(biāo)的版本庫(kù),而project1是源版本庫(kù)。其中的目標(biāo)版本庫(kù)必須為空,而且必須允許修訂版本屬性的修改,也就是在目標(biāo)的版本庫(kù)的hooks目錄里添加一個(gè)文件pre-revprop-change.bat,內(nèi)容為空即可。

3.2. 同步project2到project1

svnsync sync svn://localhost/project2
這時(shí)候你update一下你的project2的一個(gè)工作拷貝,就會(huì)發(fā)現(xiàn)有了project1的所有內(nèi)容。如果project1又有提交,這時(shí)候project2的版本庫(kù)無法看到***的變化,還需要再運(yùn)行一遍sync操作,這樣才能將***的變化同步。需要注意的是,目標(biāo)版本庫(kù)只能做成只讀的,如果目標(biāo)版本庫(kù)發(fā)生了變更,則無法繼續(xù)同步了。

3.3. 同步歷史屬性的修改

因?yàn)橥讲粫?huì)更新對(duì)歷史屬性的修改,所以svnsync還有子命令copy-revprops,可以同步某個(gè)版本的屬性。

3.4. 鉤子自動(dòng)同步

希望在每次提交時(shí)同步,則需要在源版本庫(kù)增加post-commit腳本,內(nèi)容如下:

 
 
 
  1. echo off  
  2. set SVN_HOME="D:\Subversion" 
  3. %SVN_HOME%\bin\svnsync sync --non-interactive svn://localhost/project2   

把以上內(nèi)容存放為post-commit.bat,然后放到版本庫(kù)project1下的hooks目錄下,這樣project1每次提交,都會(huì)引起project2的同步。


當(dāng)前文章:Windows下Subversion管理配置詳細(xì)說明
網(wǎng)站地址:http://www.5511xx.com/article/ccegdei.html