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

[zt] 使用svn——項(xiàng)目的目錄布局

Posted on 2009-11-03 15:39 daiybh 閱讀(319) 評(píng)論(0)  編輯 收藏 引用 所屬分類: scm
轉(zhuǎn)自:http://www.cnitblog.com/stomic/archive/2008/03/17/41043.html
Subversion有一個(gè)很標(biāo)準(zhǔn)的目錄結(jié)構(gòu),是這樣的。
比如項(xiàng)目是proj,svn地址為svn://proj/,那么標(biāo)準(zhǔn)的svn布局是
svn://proj/
|
+-trunk
+-branches
+-tags
這是一個(gè)標(biāo)準(zhǔn)的布局,trunk為主開發(fā)目錄,branches為分支開發(fā)目錄,tags為tag存檔目錄(不允許修改)。但是具體這幾個(gè)目錄應(yīng)該如何使用,svn并沒有明確的規(guī)范,更多的還是用戶自己的習(xí)慣。

對(duì)于這幾個(gè)開發(fā)目錄,一般的使用方法有兩種。我更多的是從軟件產(chǎn)品的角度出發(fā)(比如freebsd),因?yàn)榛ヂ?lián)網(wǎng)的開發(fā)模式是完全不一樣的。
第一種方法,使用trunk作為主要的開發(fā)目錄。
一般的,我們的所有的開發(fā)都是基于trunk進(jìn)行開發(fā),當(dāng)一個(gè)版本/release開發(fā)告一段落(開發(fā)、測試、文檔、制作安裝程序、打包等)結(jié)束后,代碼處于凍結(jié)狀態(tài)(人為規(guī)定,可以通過hook來進(jìn)行管理)。此時(shí)應(yīng)該基于當(dāng)前凍結(jié)的代碼庫,打tag。當(dāng)下一個(gè)版本/階段的開發(fā)任務(wù)開始,繼續(xù)在trunk進(jìn)行開發(fā)。
此時(shí),如果發(fā)現(xiàn)了上一個(gè)已發(fā)行版本(Released Version)有一些bug,或者一些很急迫的功能要求,而正在開發(fā)的版本(Developing Version)無法滿足時(shí)間要求,這時(shí)候就需要在上一個(gè)版本上進(jìn)行修改了。應(yīng)該基于發(fā)行版對(duì)應(yīng)的tag,做相應(yīng)的分支(branch)進(jìn)行開發(fā)。
例如,剛剛發(fā)布1.0,正在開發(fā)2.0,此時(shí)要在1.0的基礎(chǔ)上進(jìn)行bug修正。
按照時(shí)間的順序
  1. 1.0開發(fā)完畢,代碼凍結(jié)
  2. 基于已經(jīng)凍結(jié)的trunk,為release1.0打tag
    此時(shí)的目錄結(jié)構(gòu)為
    svn://proj/
                 +trunk/  (freeze)
                 +branches/
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  3. 2.0開始開發(fā),trunk此時(shí)為2.0的開發(fā)版
  4. 發(fā)現(xiàn)1.0有bug,需要修改,基于1.0的tag做branch
    此時(shí)的目錄結(jié)構(gòu)為
    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進(jìn)行1.0 bugfix開發(fā),在trunk進(jìn)行2.0開發(fā)
  6. 在1.0 bugfix 完成之后,基于dev_1.0_bugfix的branch做release等
  7. 根據(jù)需要選擇性的把dev_1.0_bugfix這個(gè)分支merge回trunk(什么時(shí)候進(jìn)行這步操作,要根據(jù)具體情況)
這是一種很標(biāo)準(zhǔn)的開發(fā)模式,很多的公司都是采用這種模式進(jìn)行開發(fā)的。trunk永遠(yuǎn)是開發(fā)的主要目錄。

第二種方法,在每一個(gè)release的branch中進(jìn)行各自的開發(fā),trunk只做發(fā)布使用。
這種開發(fā)模式當(dāng)中,trunk是不承擔(dān)具體開發(fā)任務(wù)的,一個(gè)版本/階段的開發(fā)任務(wù)在開始的時(shí)候,根據(jù)已經(jīng)release的版本做新的開發(fā)分支,并且基于這個(gè)分支進(jìn)行開發(fā)。還是舉上面的例子,這里面的時(shí)序關(guān)系是。
  1. 1.0開發(fā),做dev1.0的branch
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
                 +trunk/  (不擔(dān)負(fù)開發(fā)任務(wù) )
                 +branches/
                               +dev_1.0 (copy from trunk)
                 +tags/
  2. 1.0開發(fā)完成,merge dev1.0到trunk
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
                 +trunk/  (merge from branch dev_1.0)
                 +branches/
                               +dev_1.0 (開發(fā)任務(wù)結(jié)束,freeze)
                 +tags/
  3. 根據(jù)trunk做1.0的tag
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
                 +trunk/  (merge from branch dev_1.0)
                 +branches/
                               +dev_1.0 (開發(fā)任務(wù)結(jié)束,freeze)
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  4. 1.0開發(fā),做dev2.0分支
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
                 +trunk/  
                 +branches/
                               +dev_1.0 (開發(fā)任務(wù)結(jié)束,freeze)
                               +dev_2.0 (進(jìn)行2.0開發(fā))
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  5. 1.0有bug,直接在dev1.0的分支上修復(fù)
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
                 +trunk/  
                 +branches/
                               +dev_1.0 (1.0bugfix)
                               +dev_2.0 (進(jìn)行2.0開發(fā))
                 +tags/
                         +tag_release_1.0 (copy from trunk)
  6. 選擇性的進(jìn)行代碼merge
這其實(shí)是一種分散式的開發(fā),當(dāng)各個(gè)部分相對(duì)獨(dú)立一些(功能性的),可以開多個(gè)dev的分支進(jìn)行開發(fā),這樣各人/組都不會(huì)相互影響。比如dev_2.0_search和dev_2.0_cache等。但是這樣merge起來就是一個(gè)很痛苦的事情。

這里要注意一下的,第六步進(jìn)行選擇性的merge,是可以當(dāng)2.0開發(fā)結(jié)束后一起把dev_1.0(bugfix用)和dev_2.0(新版本開發(fā)用)merge回trunk。或者先把dev_1.0 merge到dev_2.0,進(jìn)行測試等之后再merge回trunk。
這兩種方法各有利弊,第一種方法是可以得到一個(gè)比較純的dev_2.0的開發(fā)分支,而第二種方法則更加的保險(xiǎn),因?yàn)橐獪y試嘛。

以上呢,就是我說的兩種開發(fā)模式了,具體哪種好,并沒有定論。這里大致的說一下各自的優(yōu)缺點(diǎn)
第一種開發(fā)模式(trunk進(jìn)行主要開發(fā),集中式):
優(yōu)點(diǎn):管理簡單
缺點(diǎn):當(dāng)開發(fā)的模塊比較多,開發(fā)人數(shù)/小團(tuán)隊(duì)比較多的時(shí)候,很容易產(chǎn)生沖突而影響對(duì)方的開發(fā)。因?yàn)樗械母膭?dòng)都有可能觸碰對(duì)方的改動(dòng)
第二重開發(fā)模式(分支進(jìn)行主要開發(fā),分散式):
優(yōu)點(diǎn):各自開發(fā)獨(dú)立,不容易相互影響。
缺點(diǎn):管理復(fù)雜,merge的時(shí)候很麻煩,容易死人。

其實(shí),這里并沒有一定之規(guī),更多的時(shí)候是兩種模式結(jié)合使用。我個(gè)人來說是采用第一種方式為主,在某些情況下使用第二種方法。
如果你還有其他的好的方法,那么請(qǐng)賜教。:)

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久成人国产| 亚洲一区二区精品在线| 在线一区视频| 久久精品一二三| 久久午夜精品一区二区| 国产精品一区二区欧美| 欧美日韩一区二区三区| 黄色成人免费观看| 性高湖久久久久久久久| 日韩午夜精品| 免费视频亚洲| 悠悠资源网久久精品| 久久成人国产精品| 亚洲永久在线| 国产精品进线69影院| 亚洲视频在线看| 99ri日韩精品视频| 欧美日本国产精品| 99国产精品久久久久久久久久| 欧美二区乱c少妇| 快播亚洲色图| 亚洲精品一区二区三区99| 欧美成人一品| 麻豆精品网站| 亚洲激情网站免费观看| 欧美激情精品久久久久久变态| 久久久亚洲精品一区二区三区| 狠狠色丁香婷婷综合久久片| 久久三级福利| 裸体女人亚洲精品一区| 亚洲人成人一区二区在线观看| 亚洲成在人线av| 免费欧美电影| 99re这里只有精品6| a91a精品视频在线观看| 国产精品视频专区| 久久久亚洲综合| 久久影院亚洲| 在线亚洲免费视频| 亚洲欧美清纯在线制服| 国产一区二区三区高清| 欧美国产激情| 国产精品成人免费视频| 久久精品欧美日韩| 美女国产精品| 亚洲欧美三级伦理| 久久久91精品国产一区二区三区 | 亚洲影视九九影院在线观看| 欧美一区深夜视频| 在线成人av.com| 亚洲在线1234| 亚洲高清三级视频| 亚洲精品自在久久| 精品电影在线观看| 欧美亚洲一区| 久久久中精品2020中文| 欧美国产第二页| 一区二区三区免费网站| 国产农村妇女毛片精品久久莱园子| 久久国产婷婷国产香蕉| 欧美88av| 久久精品水蜜桃av综合天堂| 欧美二区乱c少妇| 欧美在线精品一区| 欧美成人影音| 久久久久这里只有精品| 欧美成va人片在线观看| 欧美一区二区啪啪| 欧美国产综合视频| 午夜欧美大片免费观看 | 日韩视频不卡中文| 国产精品一区久久久久| 免费成人黄色片| 久久久久久久久久看片| 亚洲精品免费在线| 亚洲欧美国产日韩天堂区| 一区二区在线观看视频| 亚洲毛片av在线| 狠狠干综合网| 一本一本久久| 亚洲经典在线看| 亚洲欧美日韩中文播放| 久久久水蜜桃av免费网站| 日韩一区二区福利| 欧美综合国产| 亚洲一区二区三区免费观看| 久久人体大胆视频| 午夜天堂精品久久久久| 免费视频最近日韩| 久久精品99久久香蕉国产色戒| 欧美成人午夜激情视频| 亚洲性视频网站| 美女脱光内衣内裤视频久久影院 | 亚洲深夜av| 久久久久国色av免费观看性色| 亚洲在线免费| 欧美日本成人| 亚洲国产一区二区在线| 韩国欧美一区| 欧美亚洲在线播放| 久久国产免费| 亚洲国产精品99久久久久久久久| 国产日韩精品在线| 国产日韩亚洲欧美精品| 国产精品家庭影院| 亚洲制服丝袜在线| 免费观看欧美在线视频的网站| 国产精品久久久久久久app| 午夜在线a亚洲v天堂网2018| 欧美成人精品1314www| 久久影视精品| 国产日韩欧美综合| 在线亚洲一区| 一区二区三区免费观看| 欧美国产乱视频| 亚洲第一毛片| 亚洲国产欧美一区二区三区丁香婷| 亚洲欧美日本精品| 先锋影音一区二区三区| 国产精品日日摸夜夜添夜夜av| 日韩天堂在线观看| 亚洲一区二区不卡免费| 欧美丝袜第一区| 亚洲色图在线视频| 午夜视频一区| 欧美日韩亚洲一区二区三区在线| 亚洲无玛一区| 欧美一级片在线播放| 国产精品永久免费观看| 亚洲欧美日韩国产综合| 久久久久一区| 亚洲高清三级视频| 欧美黑人多人双交| 99在线观看免费视频精品观看| 亚洲视屏一区| 国产欧美日韩在线视频| 国产综合网站| 午夜久久久久久久久久一区二区| 欧美一区二区三区日韩| 韩国免费一区| 欧美成人免费在线观看| 夜夜嗨av色综合久久久综合网 | 影音先锋久久久| 久久久噜噜噜| 亚洲国产精品福利| 国产精品99久久久久久人| 国产精品一区在线观看你懂的| 久久国内精品视频| 亚洲成色777777女色窝| 亚洲婷婷综合色高清在线| 国产欧美一区二区在线观看| 久热国产精品| avtt综合网| 麻豆免费精品视频| 一区二区三区四区五区视频| 久热精品视频在线观看一区| 香港久久久电影| 亚洲欧洲一区二区在线播放| 中文欧美在线视频| 国内免费精品永久在线视频| 欧美精品一区二区精品网| 亚洲免费影视| 亚洲区欧美区| 午夜亚洲一区| 久久亚洲精品网站| 9久草视频在线视频精品| 欧美午夜精品理论片a级大开眼界| 性做久久久久久久免费看| 亚洲国产日韩欧美在线动漫| 性色av一区二区三区| 亚洲激情影院| 欧美日韩精品综合| 欧美国产视频在线| 久久成人av少妇免费| 99国产欧美久久久精品| 蜜臀99久久精品久久久久久软件| 亚洲一区国产一区| 亚洲欧洲一区| 狠狠久久婷婷| 国产精品久久网站| 欧美国产一区二区在线观看| 久久av二区| 亚洲免费在线视频| 99成人免费视频| 亚洲激情小视频| 欧美大尺度在线| 一区二区三区日韩| 亚洲网友自拍| 99riav1国产精品视频| 尤物九九久久国产精品的分类| 国产精品综合不卡av| 欧美午夜久久久| 欧美日韩国产综合网| 欧美成人在线免费观看| 久久深夜福利免费观看| 久久精品国产99精品国产亚洲性色| 99在线精品免费视频九九视| 亚洲精品美女久久7777777| 亚洲国产女人aaa毛片在线| 牛牛影视久久网|