摘要 CVS很酷,但Subversion更酷。然而,如果你在使用Eclipse進行開發,那麼你可能直到近來才能利用Subversion帶來的優點。隨著Subclipse的發行,Subversion可能會最終在你的Eclipse IDE環境充分發揮其威力而壓倒CVS。
一、SCM和Subversion簡介
軟件配置管理(SCM)是管理源碼並保持其安全的良好藝術,它能實現源碼與其他團隊成員之間保持共享,並且能夠對之加以保護。良好地利用SCM,你能夠容易地跟蹤軟件的發行和新的開發分支;這樣以來,可以更為容易地標識和修正發行產品中的錯誤。
其實,有大量的SCM工具可用,既有開源的和也有商業化的,例如StarTeam,Perforce,BitKeeper和ClearCase。在開源世界裡,事實上的SCM標准是並發版本管理系統(CVS),它被廣泛應用於世界范圍內的成百上千的開源和商業工程。然而,CVS也存在下列許多固有的缺陷,這使得它無法非常完美地適合於現代工程開發:
實質上針對文本文件的設計使得CVS處理二進制文件能力比較差。在每一次提交時,二進制文件被以整體形式傳輸和存儲,這將帶來帶寬和磁盤空間的浪費。
在CVS中,你不能移動文件和目錄。你唯一的選擇基本上就是刪除並且重新添加它們,從而失去了整個過程中的所有的文件歷史信息。
CVS中沒有實現原子提交的概念。比方說,你要把10個文件提交到服務器,而該提交操作往往在整個過程的中途停了下來。(這很可能會發生,如果某人同時提交一個文件,或甚至如果你的網絡失敗或你的PC重新啟動的話。)在這種情況下,服務器將僅記錄下你的修正的一半信息,這可能會使代碼基部分處於一種潛在地不穩定的狀態。
Subversion是一種比較新的開源SCM工具,其設計目的是力圖從根本上克服原CVS所具有的限制。它是一種良好設計的工具,具有適合於現代開發的許多新特征:
· 提交是原子化的。提交的文件都能夠被正確加入到一個新的修訂當中,否則倉庫不會被更新;並且每一個新的修訂僅由一次提交中的變化部分組成。
Subversion對文本和二進制文件使用一種巧妙的二進制技術,這既優化了網絡流量也優化了倉庫磁盤空間。
在Subversion中,每一次修訂都代表了一個特定時間內完整的目錄樹拷貝。文件和目錄可以不加限制地進行移動。
Subversion僅存儲兩個版本之間的修改內容,這不僅節約了磁盤空間,並且意味著標識一個新版本或創建一種新的子內容幾乎可以立即實現。
你可以以多種途徑來存取一個Subversion倉庫,具體則依賴於你的需要:使用HTTP或HTTPS(與WebDAV一起使用),使用快速的專利性svn:協議,或直接經由本地文件,等等。
二、Subclipse插件與Eclipse的集成
一種良好的SCM應該與你的工作環境緊密地集成到一起。沒有誰真正喜歡轉到命令行以把文件添加到倉庫。Eclipse很早就實現了CVS集成,但是直到最近Subversion用戶仍沒有被引起重視。現在,新的Subclipse插件提供了在Eclipse中的一種平滑的Subversion集成。
(一) 安裝Subclipse插件
下面,你以通常的方法從更新站點下安裝Subclipse:
1.打開"Find and install"窗口("Help>Software Updates>Find and Install")。
2.選擇"Search for new features to install"選項並點擊Next。
3.點擊"New Remote Site"並且創建一遠程站點,使用名字Subclipse和URL http://subclipse.tigris.org/update_1.0.x(參考圖1)。
4.在結果安裝窗口中,把"Subeclipse in the Features"選擇到安裝列表中,並且通過向導來開始安裝插件。
5.完成這些之後,重新啟動Eclipse。現在,你可以繼續往下進行!
圖1.安裝Subclipse插件
(二) 建立Repository定義
現在,既然你已經安裝完插件;那麼,接下來,你需要告訴它你的工程倉庫位於何處。你是在SVN Repository視圖中實現的。打開這個視圖("Windows>Show View>Other>SVN Repository")並且在上下文菜單中選擇"New>Repository Location"以顯示一個如圖2所示的對話框。輸入適當的URL並且點擊"Finish"。
圖2.添加一個倉庫定義
(三) 檢出(Check Out)一個工程
一旦建立一個倉庫,你就可以在SVN Repository視圖中浏覽所有的內容(見圖3)。我們後面將會看到,這個視圖是一種與Subversion進行交互的非常方便的方式。
圖3.SVN Repository視圖。
現在,讓我們把一個工程檢出到你的Eclipse工作區中。這只需選擇你需要的Subversion倉庫,打開上下文菜單,並且選擇"Checkout"即可。這將打開一個具有兩個選項的向導:
Check out as a Project configured using the New Project Wizard-這個選項打開新工程向導,這可以讓你使用內建的Eclipse工程類型配置工程。這個選項通常是最好用的,因為它讓你使用相同的工程模板和配置屏幕,而當你創建一個常規工程時你經常使用它們。
Check out as a Project in the Workspace-這個選項簡單地在你的包含檢出源碼的工作區中創建一個Eclipse工程。
在以上兩種情況下,你仍然需要更新工程的構建路徑,因為在檢出該工程源碼之前,Eclipse不能確定這些Java源碼所在的位置。
(四) 把一個新工程導入到倉庫中
如果你只是啟動了一個新的工程,那麼你需要把它導入到Subversion倉庫。Subclipse提供了一種方便的方式來直接從你的IDE內部實現這一點。為此,只需要從Package Explorer視圖下選擇你的工程,並且在上下文菜單中選擇"Team>Share Project"。你可以使用現有倉庫之一或創建一新的倉庫定義。在你指定倉庫和工程名之後,你能指定你想放到倉庫中的文件和目錄並且提供一個初始注釋(見圖4)。這種方法特別有用,因為它讓你有選擇地導入僅由Subversion管理的文件,即使該工程還包含其它文件(例如生成的類,臨時文件或其它不是必需的內容等)。
圖4.把一個工程導入到一個Subversion倉庫中
三、在Eclipse中使用Subversion
現在,既然你的支持Subversion的工程已經啟動並且運行起來,那麼大多數必要的Subversion命令就可經由"Team"上下文菜單存取(參考圖5)。你可以在Package Explorer中看到你的本地文件的狀態(參考圖6),其中,任何修改了的文件都被標記上一個星號。存儲在倉庫中的文件都顯示一個小黃桶圖標(代表了一個數據庫);還沒有被添加到倉庫中的文件以一個問號顯示。
圖5.大多數Subversion命令能被經由Team菜單存取
圖6.你可以在Package Explorer中看到本地文件的狀態
(一) 與Repository保持同步
從倉庫中更新你的文件並且把你的變化提交到倉庫是相當直接的過程,這可以使用"Team>Update and Team>Commit"菜單選項來實現。在提交你的變化之前,你可能想看一下自從你的上次更新以來是否服務器上有任何文件被修改。為此,你可以使用"Team >Synchronize with Repository"。這個命令讓你看到有哪些內容已經被局部地修改,有哪些內容在服務器上修改,以及這兩種修改之間的任何沖突(參考圖7)。你還可以以可視化方式看到沖突的版本,並且在提交你的變化之前糾正任何比較突出的沖突。
圖7.與倉庫保持同步
(二) 使用屬性
屬性是Subversion具有創新性的特征之一。在Subversion中,你可以把元數據("properties")關聯到任何文件或目錄。你可以定義任何你喜歡的屬性,但是Subversion也提供了一些有用的內置屬性,例如下面圖8中所提供的這些屬性:
svn:executable屬性,允許你在支持這種能力的操作系統上設置一個文件的可執行標志。
svn:need-lock屬性,可以用來在文件(例如,對二進制文件非常有用)上強加排斥鎖。一個定義了svn:need-lock屬性的文件一次只能被一個人修改。當該文件被檢出時,它是只讀的。如果你想修改該文件,你需要首先使用"Team>Lock"菜單選項。之後,使用"Team>Unlock"釋放該文件,或僅提交你的變化。這一行為將釋放該鎖並且讓其它的用戶也得到該文件上的一把鎖。
圖8.把一個Subversion屬性添加到一個文件中
(三) Tag和Branch
在Subversion中,很容易創建新的tag和branch。你可以使用tag來標識一個特定的版本(使用一種可讀的名字,例如"Release 1.0")。;而一個branch用於新的開發工作而不影響主源碼基(稱作trunk)。在一個branch上的開發仍會繼續進行,直到開發者已經為把變化集成回主trunk作好准備。
在Subversion中,branch和tag都是通過制作給定修訂的一個虛擬副本(以另一個名字和/或另一個目錄)創建的。在常規情況下,branch存儲在branches目錄下,tag位於tags目錄下,盡管在實踐中為了滿足你的工程你可以使用自己的任何定制。
從Eclipse中,"Team>Branch/Tag"菜單能夠使你創建branch和tag(參考圖9)。其中,Browse按鈕提供了一種方便的方法來查看有哪些branch和tag存在於倉庫中。
當你使用"Team>Switch"創建成功一個新的branch或tag時,你可以非常容易地在branches之間進行切換。無論何時你切換到一個不同的branch(或返回到trunk),Subversion將僅更新文件(它需要保持你的當前工作的副本與目的branch之間的同步)。
圖9.創建一個新的branch或tag
(四) 修訂歷史
象大多數SCM系統一樣,Subversion讓你跟蹤你的源碼的變化。"Team>Show in Resource History"菜單選項能夠使你查詢這些變化的列表(包括對一個文件,目錄或甚至整個工程的改變)(見圖10)。
記住,在Subversion中,提交是原子性的-一次提交由一組文件變化和一個全局注釋組成。"SVN Resource History"視圖向你顯示每一次提交的一個簡明視圖,包括修改的文件和相關注釋。
圖10.歷史資源
四、結論
Subversion是一種強有力的和非常靈活的SCM工具,也是CVS的一個成功的後繼者。結合Subclipse,Subversion能最終在你的Eclipse IDE環境中得到全面的發揮。