关于SVN 目录结构
Subversion有一個很標準的目錄結構,是這樣的。比如項目是proj,svn地址為svn://proj/,那么標準的svn布局是
?? svn://proj/
?? |
?? +-trunk
?? +-branches
?? +-tags??
?? 這 是一個標準的布局,trunk為主開發目錄,branches為分支開發目錄,tags為tag存檔目錄(不允許修改)。但是具體這幾個目錄應該如何使 用,svn并沒有明確的規范,更多的還是用戶自己的習慣。
??? 對于這幾個開發目錄,一般的使用方法有兩種。我更多的是從軟件產品的角度出發 (比如freebsd),因為互聯網的開發模式是完全不一樣的。
第一種方法,使用trunk作為主要的開發目錄。
??? 一般的,我們的所有的開 發都是基于trunk進行開發,當一個版本/release開發告一段落(開發、測試、文檔、制作安裝程序、打包等)結束后,代碼 處于凍結狀態(人為規定,可以通過hook來進行管理)。此時應該基于當前凍結的代碼庫,打tag。當下一個版本/階段的開發任務開始,繼續在trunk 進行開發。此時,如果發現了上一個已發行版本(Released Version)有一些bug,或者一些很急迫的功能要求,而正在開發的版本(Developing Version)無法滿足時間要求,這時候就需要在上一個版本上進行修改了。應該基于發行版對應的tag,做相應的分支(branch)進行開發。例 如,剛剛發布1.0,正在開發2.0,此時要在1.0的基礎上進行bug修正。
按照時間的順序
此時的目錄結構為
svn://proj/
+trunk/ (freeze)
+branches/
+tags/
??? +tag_release_1.0 (copy from trunk)
此時的目錄結構 為
svn://proj/
+trunk/ ( dev 2.0 )
+branches/
???? +dev_1.0_bugfix (copy from tag/release_1.0)
+tags/
???? +release_1.0 (copy from trunk)
??? 這是一種很標準的開發模 式,很多的公司都是采用這種模式進行開發的。trunk永遠是開發的主要目錄。
??? 第二種方法,在每一個release的branch中進行 各自的開發,trunk只做發布使用。這種開發模式當中,trunk是不承擔具體開發任務的,一個版本/階段的開發任務在開始的時候,根據已經 release的版本做新的開發分支,并且基于這個分支進行開發。還是舉上面的例子,這里面的時序關系是。
此時的目錄結構
svn://proj/
+trunk/ (不擔負開發任務 )
+branches/
??? +dev_1.0 (copy from trunk)
+tags/
此時的目 錄結構
svn://proj/
+trunk/ (merge from branch dev_1.0)
+branches/
???? +dev_1.0 (開發任務結束,freeze)
+tags/
此時的目錄結構
svn://proj/
+trunk/ (merge from branch dev_1.0)
+branches/
??? +dev_1.0 (開發任務結束,freeze)
+tags/
??? +tag_release_1.0 (copy from trunk)
此時的目錄結構
svn://proj/
+trunk/?
+branches/
??? +dev_1.0 (開發任務結束,freeze)
??? +dev_2.0 (進行2.0開發)
+tags/
??? +tag_release_1.0 (copy from trunk)
此時的目錄結構
svn://proj/
+trunk/?
+branches/
??? +dev_1.0 (1.0bugfix)
??? +dev_2.0 (進行2.0開發)
+tags/
??? +tag_release_1.0 (copy from trunk)
??? 這其實是一種分散式的開發,當各個部分相對 獨立一些(功能性的),可以開多個dev的分支進行開發,這樣各人/組都不會相互影響。比如dev_2.0_search和dev_2.0_cache 等。但是這樣merge起來就是一個很痛苦的事情。
??? 這里要注意一下的,第六步進行選擇性的merge,是可以當2.0開發結束后一起把 dev_1.0(bugfix用)和dev_2.0(新版本開發 用)merge回trunk。或者先把dev_1.0 merge到dev_2.0,進行測試等之后再merge回trunk。
???? 這兩種方法各有利弊,第一種方法是可以得到一個比較純的dev_2.0的 開發分支,而第二種方法則更加的保險,因為要測試嘛。
????? 以上呢,就是我說的兩種開發模式了,具體哪種好,并沒有定論。這里大致的說一下各自 的優缺點
????? 第一種開發模式(trunk進行主要開發,集中式):
????????? 優點:管理簡單
????????? 缺點:當開發的模塊比較多,開發人數/小團隊比較多 的時候,很容易產生沖突而影響對方的開發。因為所有的改動都有可能觸碰對方的改動
????? 第二重開發模式(分支進行主要開發,分散式):
????????? 優點:各 自開發獨立,不容易相互影響。
????????? 缺點:管理復雜,merge的時候很麻煩,容易死人。
????? 其實,這里并沒有一定之規,更多的時候是兩種 模式結合使用。
轉載于:https://www.cnblogs.com/zhangchenliang/p/4874440.html
總結
以上是生活随笔為你收集整理的关于SVN 目录结构的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 建行电子承兑汇票接收流程 建行电子承兑汇
- 下一篇: 创维汽车发布车载语音大模型“