一直以來(lái)對(duì)于自己的項(xiàng)目都是使用CVS進(jìn)行管理,聽(tīng)說(shuō)Subversion很久了,但是都沒(méi)有時(shí)間去嘗試。想想時(shí)間都是省出來(lái)的,于是決定,學(xué)一點(diǎn),不多,積累成河嘛。
Subversion和CVS相比,除了包含了CVS的全部特性之外,也加入了新的理念。
新理念
1、路徑、改名、以及文件meta-data也可進(jìn)入版本控制范圍。
缺少這些特性是CVS被抱怨多的方面之一,subversion不止對(duì)文件內(nèi)容和文件存放位置加入控制,也對(duì)目錄,拷貝,重命名操作加入版本控制。它也允許文件/目錄的相關(guān)元數(shù)據(jù)meta-data和文件/目錄本身一起被版本控制起來(lái),并提供一種機(jī)制對(duì)文件的執(zhí)行權(quán)限進(jìn)行控制。
2、Commit動(dòng)作真正成為原子級(jí)的操作了。
直到整個(gè)commit動(dòng)作都成功前不會(huì)有任何部分的commit會(huì)生效。版本修訂號(hào)只是預(yù)確認(rèn),而不是對(duì)文件預(yù)確認(rèn)。(翻譯不出來(lái) -_-;)日志信息將綁定到修訂信息,而不是象CVS那樣冗余的存儲(chǔ)下來(lái)。
3、提供Apache網(wǎng)絡(luò)服務(wù)器∠睿?С�WebDAV/DeltaV協(xié)議。
Subversion可以使用基于http協(xié)議的WebDAV/DeltaV協(xié)議進(jìn)行網(wǎng)絡(luò)通訊,并由Apache服務(wù)器提供源碼倉(cāng)庫(kù)方的網(wǎng)絡(luò)瀏覽服務(wù)。這為Subversion提供了比CVS更好的協(xié)同工作能力,并提供了各式各樣的自由的關(guān)鍵特性:授權(quán),基于路徑的授權(quán),線性壓縮,以及基本源碼倉(cāng)庫(kù)瀏覽。
4、獨(dú)立服務(wù)器選項(xiàng)
Subversion也能提供獨(dú)立服務(wù)器選項(xiàng),使用自定的協(xié)議(不是每個(gè)人都想運(yùn)行Apache2.x)獨(dú)立服務(wù)器可以作為系統(tǒng)的inetd服務(wù)運(yùn)行,并提供基本的授權(quán)。它也能使用ssh進(jìn)行加密。
5、建立分支和標(biāo)簽操作成為不耗時(shí)的操作。
這些動(dòng)作沒(méi)理由耗時(shí),所以我們不再讓它們耗時(shí)。
6、分支與標(biāo)簽的實(shí)現(xiàn)都是基于底層的拷貝操作,一個(gè)拷貝占用一塊固定大小的空間。任何拷貝都可以作為一份標(biāo)簽;假如你開(kāi)始對(duì)某個(gè)版本的拷貝進(jìn)行commit動(dòng)作,那它也成為一個(gè)分支。(這與CVS的"分支節(jié)點(diǎn)做標(biāo)簽"方式不同)
7、天然的client/server結(jié)構(gòu),層次化庫(kù)設(shè)計(jì)。
Subversion從設(shè)計(jì)之初即采用client/server機(jī)構(gòu);因此避免了困擾CVS了許久的一些維護(hù)性難題。
代碼被構(gòu)建為一組帶有詳細(xì)接口說(shuō)明的模塊,用以方便的由其他應(yīng)用程序進(jìn)行調(diào)用。
8、Client/server協(xié)議向雙方發(fā)送對(duì)比差異。
網(wǎng)絡(luò)協(xié)議利用寬帶有效地發(fā)送對(duì)比差異給客戶端和服務(wù)器端雙方。( CVS只是 server->client,?沒(méi)有client->server )
9、資源消耗與數(shù)據(jù)改變的大小成正比,而不是與數(shù)據(jù)本身大小成正比一般來(lái)說(shuō),一項(xiàng)Subversion操作所需時(shí)間與操作終變化的大小成正比。而不是與操作所觸及的整個(gè)項(xiàng)目的大小成正比,這是Subversion源代碼倉(cāng)庫(kù)模型的一個(gè)特性。
10、有效的處理二進(jìn)制文件
Subversion對(duì)于二進(jìn)制文件和文本文件的處理同樣有效,因?yàn)閟ubversion使用一種二進(jìn)制差異比較算法來(lái)增量存儲(chǔ)那些連續(xù)的修訂本。
11、易于語(yǔ)法分析的輸出。
所有Subversion命令行客戶端的輸出都是仔細(xì)設(shè)計(jì)的,可輕松為人所理解,也適于程序自動(dòng)解析。可進(jìn)行腳本語(yǔ)言處理將是下一步優(yōu)先考慮的特性。
好了,開(kāi)始使用吧。
Subversion到目前的安裝已經(jīng)非常簡(jiǎn)單了。到Subversion網(wǎng)站下載Windows下的安裝文件,簡(jiǎn)單的步驟可以完成安裝,而且安裝程序已經(jīng)自動(dòng)注冊(cè)Path,直接在命令行模式可以使用了。
首先初始化Repository,輸入命令:
svnadmin create D:TestRepository
然后,把現(xiàn)有的項(xiàng)目的目錄結(jié)構(gòu)以及文件導(dǎo)入到Repository中:
svn import D:ProjectsProject1 file:///D:TestRepositoryProject1 -m “初始化“
用啟動(dòng)服務(wù)
svnserve -d -r D:TestRepository
客戶端Checkout
svn checkout svn://主機(jī)名/Project1?? (即獲取Project1的項(xiàng)目)
以上都是很簡(jiǎn)單的命令。而且上面只用到了一種服務(wù)模式,Apache的還在嘗試中。
目前只用到了Subversion的基本功能,已經(jīng)感覺(jué)不錯(cuò)了,覺(jué)得入門(mén)很輕松,幫助文檔也比CVS要好的多。
Subversion也有圖形的客戶端,可以在 TortoiseSVN 找到。
Subversion也VS.Net的插件,可以在AnkhSVN 找到。
TortoiseSVN相信不錯(cuò),因?yàn)橐郧坝眠^(guò)它的另一個(gè)For CVS的工具,可以和瀏覽器結(jié)合在一起,非常方便和美觀。
服務(wù)
Subversion具有兩種服務(wù)模式,一個(gè)是作為Apache的模塊,另一個(gè)是自定義協(xié)議的Subserve服務(wù)。作為Apache的模塊,客戶端可以通過(guò)WebDAV/DeltaV協(xié)議訪問(wèn)Repository,而使用Subserve則使用
Subversion的自定義協(xié)議。
下表是兩種服務(wù)模式的比較:
功能
|
Apache + mod_dav_sub
|
Svnserve
|
驗(yàn)證方式
|
基于HTTPS的X.509、LDAP、NTLM或其他Apache支持的驗(yàn)證
|
CRAM-MD5或者SSH
|
用戶帳戶管理
|
私有的用戶文件
|
私有的用戶文件或已有的系統(tǒng)帳戶
|
授權(quán)管理
|
blanket read/write aclearcase/" target="_blank" >ccess或單一目錄的訪問(wèn)控制
|
blanket read/write access
|
加密
|
可選的SSL
|
可選的SSH隧道
|
交互性
|
可通過(guò)支持WebDAV的客戶端訪問(wèn)
|
無(wú)交互性
|
Web訪問(wèn)
|
有限的內(nèi)置支持,或通過(guò)第三方的工具,例如ViewCVS
|
通過(guò)第三方的支持,如ViewCVS
|
速度
|
稍慢
|
稍快
|
初始安裝
|
稍復(fù)雜
|
相當(dāng)簡(jiǎn)單
|