青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

[zt] 使用svn——項目的目錄布局

Posted on 2009-11-03 15:39 daiybh 閱讀(316) 評論(0)  編輯 收藏 引用 所屬分類: scm
轉自:http://www.cnitblog.com/stomic/archive/2008/03/17/41043.html
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修正。
按照時間的順序
  1. 1.0開發完畢,代碼凍結
  2. 基于已經凍結的trunk,為release1.0打tag
    此時的目錄結構為
    svn://proj/
                 +trunk/  (freeze)
                 +branches/
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  3. 2.0開始開發,trunk此時為2.0的開發版
  4. 發現1.0有bug,需要修改,基于1.0的tag做branch
    此時的目錄結構為
    svn://proj/
                 +trunk/  ( dev 2.0 )
                 +branches/
                               +dev_1.0_bugfix (copy from tag/release_1.0)
                 +tags/
                         +release_1.0 (copy from trunk)
  5. 在1.0 bugfix branch進行1.0 bugfix開發,在trunk進行2.0開發
  6. 在1.0 bugfix 完成之后,基于dev_1.0_bugfix的branch做release等
  7. 根據需要選擇性的把dev_1.0_bugfix這個分支merge回trunk(什么時候進行這步操作,要根據具體情況)
這是一種很標準的開發模式,很多的公司都是采用這種模式進行開發的。trunk永遠是開發的主要目錄。

第二種方法,在每一個release的branch中進行各自的開發,trunk只做發布使用。
這種開發模式當中,trunk是不承擔具體開發任務的,一個版本/階段的開發任務在開始的時候,根據已經release的版本做新的開發分支,并且基于這個分支進行開發。還是舉上面的例子,這里面的時序關系是。
  1. 1.0開發,做dev1.0的branch
    此時的目錄結構
    svn://proj/
                 +trunk/  (不擔負開發任務 )
                 +branches/
                               +dev_1.0 (copy from trunk)
                 +tags/
  2. 1.0開發完成,merge dev1.0到trunk
    此時的目錄結構
    svn://proj/
                 +trunk/  (merge from branch dev_1.0)
                 +branches/
                               +dev_1.0 (開發任務結束,freeze)
                 +tags/
  3. 根據trunk做1.0的tag
    此時的目錄結構
    svn://proj/
                 +trunk/  (merge from branch dev_1.0)
                 +branches/
                               +dev_1.0 (開發任務結束,freeze)
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  4. 1.0開發,做dev2.0分支
    此時的目錄結構
    svn://proj/
                 +trunk/  
                 +branches/
                               +dev_1.0 (開發任務結束,freeze)
                               +dev_2.0 (進行2.0開發)
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  5. 1.0有bug,直接在dev1.0的分支上修復
    此時的目錄結構
    svn://proj/
                 +trunk/  
                 +branches/
                               +dev_1.0 (1.0bugfix)
                               +dev_2.0 (進行2.0開發)
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  6. 選擇性的進行代碼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.0 merge到dev_2.0,進行測試等之后再merge回trunk。
這兩種方法各有利弊,第一種方法是可以得到一個比較純的dev_2.0的開發分支,而第二種方法則更加的保險,因為要測試嘛。

以上呢,就是我說的兩種開發模式了,具體哪種好,并沒有定論。這里大致的說一下各自的優缺點
第一種開發模式(trunk進行主要開發,集中式):
優點:管理簡單
缺點:當開發的模塊比較多,開發人數/小團隊比較多的時候,很容易產生沖突而影響對方的開發。因為所有的改動都有可能觸碰對方的改動
第二重開發模式(分支進行主要開發,分散式):
優點:各自開發獨立,不容易相互影響。
缺點:管理復雜,merge的時候很麻煩,容易死人。

其實,這里并沒有一定之規,更多的時候是兩種模式結合使用。我個人來說是采用第一種方式為主,在某些情況下使用第二種方法。
如果你還有其他的好的方法,那么請賜教。:)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产麻豆视频精品| 国产婷婷97碰碰久久人人蜜臀| 欧美日韩在线观看一区二区三区| 久久久久99| 日韩视频一区二区三区| 国产精品久久午夜夜伦鲁鲁| 欧美主播一区二区三区| 日韩亚洲欧美一区| 欧美国产日韩精品| 免费不卡中文字幕视频| 久久九九久久九九| 亚洲天堂av图片| 日韩网站在线观看| 亚洲精品精选| 欧美理论在线播放| 欧美成人激情视频免费观看| 久久精品国产77777蜜臀 | 久久狠狠亚洲综合| 亚洲一区二区三区四区五区午夜| 在线播放视频一区| 激情五月综合色婷婷一区二区| 国产精品免费视频观看| 国产精品极品美女粉嫩高清在线 | 这里只有精品视频| 亚洲五月六月| 亚洲私人影院在线观看| 一区二区三区四区五区精品视频| 国产一区二区三区在线观看免费视频| 欧美日韩国产在线一区| 欧美日韩不卡| 永久久久久久| 亚洲色图制服丝袜| 欧美大香线蕉线伊人久久国产精品| 久久夜色精品国产| 亚洲国内自拍| 小黄鸭精品aⅴ导航网站入口| 午夜精品久久久久久久99热浪潮 | 欧美精品在线观看| 国产精品一区二区久久久| 激情婷婷亚洲| 亚洲欧美中日韩| 亚洲精品视频免费在线观看| 性欧美1819sex性高清| 欧美成人久久| 欧美电影免费观看网站| 欧美一区二区三区四区在线观看地址 | 欧美日韩精品欧美日韩精品一| 国产精品久久福利| 最新69国产成人精品视频免费| 久久精品视频在线| 狠狠操狠狠色综合网| 亚洲影音一区| 久久riav二区三区| aⅴ色国产欧美| 欧美色图天堂网| 亚洲一区二区三区777| 亚洲精品免费观看| 欧美日韩高清在线| 在线视频欧美日韩| 一区二区三区四区五区在线 | 在线成人激情| 欧美福利视频在线观看| 久久婷婷影院| 亚洲激情在线视频| 欧美不卡在线视频| 欧美激情一区二区三区全黄 | 欧美成人免费在线| 免费h精品视频在线播放| 亚洲国产欧美久久| 99re在线精品| 国产一区二区中文字幕免费看| 欧美在线观看一二区| 久久中文字幕一区| 亚洲在线1234| 暖暖成人免费视频| 亚洲一区二区三区视频播放| 亚洲欧美一级二级三级| 国产欧美日韩精品a在线观看| 久久天堂av综合合色| 欧美日韩国产天堂| 欧美成人嫩草网站| 久久亚洲综合| 欧美日韩一区二区三| 一区二区三区色| 久久精品一二三| 亚洲国产日韩美| 欧美日韩另类国产亚洲欧美一级| 亚洲精品国精品久久99热| 亚洲国产网站| 国产精品狠色婷| 久久久噜噜噜久久中文字幕色伊伊| 欧美一区综合| ●精品国产综合乱码久久久久| 久久av资源网| 亚洲免费观看高清在线观看 | 麻豆91精品| 一本色道久久综合| 久久精品国产欧美亚洲人人爽| 1000部精品久久久久久久久| 欧美日韩成人一区二区| 午夜精品久久久久99热蜜桃导演| 久久资源在线| 欧美在线观看一二区| 一区二区三区 在线观看视频| 国产一区二区三区精品欧美日韩一区二区三区| 欧美在线一二三区| 一本色道久久精品| 日韩一级黄色av| 亚洲国产成人porn| 欧美大片在线影院| 免费av成人在线| 老司机成人网| 欧美成人免费网站| 亚洲电影中文字幕| 亚洲狠狠丁香婷婷综合久久久| 久久久99爱| 国内外成人免费激情在线视频| 欧美精品v国产精品v日韩精品| 欧美综合国产| 久久久在线视频| 美女网站在线免费欧美精品| 久久国产日韩| 欧美激情国产精品| 欧美日韩国产探花| 国产精品久久久久aaaa| 国产色视频一区| 亚洲精品国产精品久久清纯直播| 最近中文字幕mv在线一区二区三区四区| 国产欧美视频一区二区| 国产一区二区高清| 亚洲人成网站777色婷婷| 亚洲精品在线一区二区| 亚洲精品一区二区三| 亚洲欧美日韩一区二区三区在线| 欧美亚洲视频| 欧美jizz19hd性欧美| 一本色道久久综合精品竹菊 | 欧美日韩精品中文字幕| 国产精品影音先锋| 亚洲高清电影| 亚洲欧美一区二区三区在线| 欧美成人午夜视频| 亚洲欧美日韩在线不卡| 欧美不卡三区| 红桃视频欧美| 欧美在线视频一区二区| 日韩亚洲欧美中文三级| 久久天天综合| 狠狠色伊人亚洲综合网站色| 亚洲视频www| 亚洲人人精品| 欧美另类视频在线| 一区二区在线免费观看| 久久国产色av| 亚洲激情电影在线| 亚洲精品小视频在线观看| 久久久噜噜噜久噜久久 | 久久精品人人做人人爽| 国产精品一区2区| 午夜精品福利在线观看| 亚洲自拍偷拍麻豆| 国产日韩一区二区三区在线播放 | 久久久久久久999精品视频| 一区二区精品国产| 国产精品九九| 久久久久久亚洲精品不卡4k岛国| 久久精品国产第一区二区三区| 国产精品视频导航| 久久只有精品| 欧美午夜激情小视频| 亚洲欧美日本国产专区一区| 午夜亚洲视频| 99国产精品视频免费观看| 亚洲免费视频成人| 最新国产拍偷乱拍精品| 亚洲永久在线| 亚洲人午夜精品| 欧美一区二区三区免费视频| 亚洲国产福利在线| 欧美一区在线直播| 中文无字幕一区二区三区| 久久岛国电影| 亚洲欧美中文另类| 欧美日韩一区三区| 欧美高清视频在线播放| 国产日产欧美a一级在线| 亚洲国产精品日韩| 亚洲人成免费| 欧美激情在线观看| 最新精品在线| 在线视频一区二区| 欧美日韩国产综合在线| 亚洲国产一区二区三区青草影视| 国产午夜精品美女视频明星a级 | 亚洲福利国产| 久久精品国产第一区二区三区最新章节 | 国产精品毛片在线| 亚洲国产日韩欧美在线图片| 韩国三级电影久久久久久| 欧美一区二区三区日韩视频|