成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SVN項目---目錄布局詳解

開發 項目管理
本文和大家學習一下SVN項目---目錄布局,通過兩種方法介紹,在這里和大家分享一下,看完本文你肯定有不少收獲,希望本文能教會你更多東西。

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

【編輯推薦】

  1. SVN屬性設置名師詳解
  2. 學習筆記 SVN簡易使用手冊詳解
  3. 常用SVN目錄結構簡明介紹
  4. SVN配置文檔新手指南
  5. 名師推薦 SVN使用說明指導

 

責任編輯:佚名
相關推薦

2010-05-26 19:05:06

SVN庫

2010-06-02 10:36:41

SVN開發

2010-06-02 10:47:37

SVN開發

2010-05-20 12:43:37

SVN Update命

2010-05-27 11:12:10

SVN目錄結構

2010-05-27 10:32:19

SVN配置文檔

2010-06-02 13:24:02

SVN用法

2010-06-01 19:06:27

刪除SVN

2010-05-27 09:41:05

SVN沖突

2010-05-31 16:29:22

SVN權限配置

2010-05-27 15:53:35

SVN屬性設置

2010-05-26 19:36:34

SVN目錄結構

2010-05-27 10:53:54

SVN目錄結構

2010-05-21 10:13:30

Svn import子

2010-05-24 09:11:06

SVN版本庫

2010-05-24 11:16:43

SVN更新URL

2010-05-27 16:06:13

SVN設置

2010-05-31 09:47:40

2010-05-25 17:13:26

SVN子命令log

2011-08-11 13:10:34

XcodeSVN
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: www.一级片| 欧美mv日韩mv国产网站91进入 | 99精品视频在线观看 | 欧美日韩精品一区二区三区视频 | 欧美人人| 中文字幕在线一区二区三区 | 国产伦精品一区二区三区高清 | 中文字幕亚洲一区 | 欧美性jizz18性欧美 | 亚洲视频 欧美视频 | 中文字幕加勒比 | 亚洲午夜视频在线观看 | 日韩成人性视频 | 久久成人激情 | 国内av在线 | 亚洲精品电影网在线观看 | 在线播放第一页 | 青青草网站在线观看 | 色花av| 欧美日韩一区二区视频在线观看 | 免费看爱爱视频 | 你懂的国产| 日韩精品一区二区三区久久 | 久久99久久98精品免观看软件 | 激情久久网 | 91大神在线资源观看无广告 | 亚洲在线| 精品成人佐山爱一区二区 | 毛片一级片 | 国产精品99精品久久免费 | 亚洲免费高清 | 久久久久久国 | 日本一区二区三区视频在线 | 久久九九影视 | 欧美精品日韩 | 亚洲精品2区 | 亚洲风情在线观看 | 韩日视频在线观看 | 亚洲网站免费看 | 日韩精品一区二区三区中文在线 | 久久蜜桃资源一区二区老牛 |