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

大龍的博客

常用鏈接

統(tǒng)計

最新評論

使用svn——項目的目錄布局 (轉(zhuǎn))

Subversion有一個很標準的目錄結(jié)構,是這樣的。
比如項目是proj,svn地址為svn://proj/,那么標準的svn布局是
svn://proj/
|
+-trunk
+-branches
+-tags
這是一個標準的布局,trunk為主開發(fā)目錄,branches為分支開發(fā)目錄,tags為tag存檔目錄(不允許修改)。但是具體這幾個目錄應該如何使用,svn并沒有明確的規(guī)范,更多的還是用戶自己的習慣。

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

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

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

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

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

posted on 2010-04-15 15:16 大龍 閱讀(759) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   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>
            欧美~级网站不卡| 久久看片网站| 久久久久久亚洲精品中文字幕| 欧美sm极限捆绑bd| 在线亚洲+欧美+日本专区| 99视频日韩| 亚洲国产精品一区二区第一页| 亚洲免费av电影| 欧美中文日韩| 国产欧美精品| 日韩视频永久免费| 亚洲三级影院| 欧美丝袜一区二区三区| 欧美不卡在线视频| 黄色综合网站| 免费国产自线拍一欧美视频| 夜夜爽av福利精品导航| 激情五月综合色婷婷一区二区| 亚洲欧美视频在线| 亚洲一区二区视频在线| 久久视频一区二区| 亚洲一区在线观看免费观看电影高清| 亚洲一区二区视频在线| 亚洲在线观看视频| 亚洲欧美日本日韩| 久久精品久久综合| 日韩午夜三级在线| 亚洲一区二区视频| 91久久国产综合久久蜜月精品| 日韩西西人体444www| 一区二区欧美在线观看| 99精品国产一区二区青青牛奶 | 亚洲成人在线| 欧美日韩国产区一| 久久精品动漫| 亚洲一区欧美| 麻豆国产精品777777在线| 亚洲欧美日韩一区| 99在线观看免费视频精品观看| 毛片一区二区三区| 亚洲国产精品一区二区www在线| 亚洲国产精品传媒在线观看| 欧美日韩亚洲视频| 亚洲欧美电影在线观看| 免费不卡欧美自拍视频| 9i看片成人免费高清| 99精品欧美一区| 国产亚洲人成a一在线v站| 欧美成人在线免费观看| 亚洲美女电影在线| 久久久精品性| 一本色道久久综合一区| 欧美激情精品久久久久久大尺度 | 久久久免费精品视频| 久久久人成影片一区二区三区| 久久久久综合一区二区三区| 在线欧美三区| 久久久久国色av免费看影院| 久久精品国产精品亚洲综合| 久久久999| 在线观看欧美日本| 久久久777| 亚洲欧洲日韩女同| 亚洲精品之草原avav久久| 欧美日韩色一区| 午夜精品在线看| 欧美在线视频一区二区三区| 久久精品中文字幕一区二区三区| 免费人成精品欧美精品| 国产精品你懂得| 99在线热播精品免费99热| 亚洲午夜久久久久久久久电影院| 国产主播一区二区三区| 狠狠色狠狠色综合人人| 一区二区三区在线免费观看| 免费久久精品视频| 久久久久久久一区二区| av成人手机在线| 久久综合九色99| 99精品欧美一区| 99这里只有精品| 亚洲电影第1页| 久久先锋资源| 久久久久国产精品厨房| 欧美成人官网二区| 久久国产乱子精品免费女| 一本色道久久88综合日韩精品| 国产日韩精品视频一区| 久久国产日本精品| 欧美一区二区免费| 亚洲影视在线| 亚洲精品乱码久久久久久蜜桃麻豆| 夜夜嗨av一区二区三区网站四季av | 亚洲一级电影| 国产欧美精品在线观看| 久久一本综合频道| 国产精品99久久久久久白浆小说 | 一区二区电影免费在线观看| 久久先锋影音av| 国产精品99久久99久久久二8| 一区二区三区在线观看欧美| 欧美精品午夜| 免费成人你懂的| 久久久另类综合| 亚洲欧美日韩在线观看a三区| 久久视频在线免费观看| 亚洲欧洲日韩在线| 欧美高清视频一区二区三区在线观看| 亚洲一区精品视频| 精品成人在线视频| 亚洲国产精品久久久久婷婷884| 久久久久国色av免费观看性色| 91久久精品美女高潮| 免费黄网站欧美| 99re视频这里只有精品| 一区二区视频欧美| 国产精品久久久久久一区二区三区| 久久亚洲图片| 国产精品人成在线观看免费| 亚洲精品三级| 国产精品视频免费一区| 亚洲第一毛片| 久久99在线观看| 裸体丰满少妇做受久久99精品| 久久精品卡一| 亚洲美女网站| 久久噜噜噜精品国产亚洲综合| 亚洲一区二区在线看| 欧美www视频在线观看| 国产一区观看| 中文有码久久| 久久爱www久久做| 国产亚洲美州欧州综合国| 亚洲视频免费在线| 久久久久久久久久久久久久一区| 亚洲欧美国内爽妇网| 欧美成人精品福利| 欧美国产精品专区| 亚洲精品欧美极品| 亚洲欧美日韩另类| 欧美精品久久99久久在免费线| 国产一区二区三区在线观看视频| 在线观看日韩av电影| 久久精品水蜜桃av综合天堂| 久久精品人人做人人爽电影蜜月| 亚洲在线播放| 亚洲在线观看| 欧美视频免费看| 99亚洲精品| 亚洲欧美成人网| 亚洲第一页自拍| 亚洲免费在线观看视频| 欧美日韩另类字幕中文| 99精品欧美一区| 一本色道久久综合亚洲精品不卡 | 亚洲一区二区3| 久久综合一区| 性久久久久久久久久久久| 欧美午夜精品久久久久久人妖| 亚洲激情av| 久久综合色天天久久综合图片| 国产精品日韩在线观看| 午夜精品福利一区二区三区av| 亚洲日本乱码在线观看| 国产精品高潮呻吟久久av无限| 欧美午夜视频在线观看| 久久免费视频网| 国产精品xxxxx| 欧美在线观看视频一区二区三区| 亚洲午夜未删减在线观看| 欧美日韩在线观看视频| 久久久久久黄| 国产日韩欧美不卡在线| 亚洲美女性视频| 极品尤物一区二区三区| 亚洲午夜av在线| 91久久精品国产91久久性色tv| 最新69国产成人精品视频免费| 久久婷婷蜜乳一本欲蜜臀| 欧美国产综合一区二区| 欧美一级淫片播放口| 裸体女人亚洲精品一区| 亚洲欧美日韩精品久久奇米色影视| 你懂的成人av| 欧美成熟视频| 欧美激情一区二区三区| 开心色5月久久精品| 在线电影一区| 久久久免费精品| 久久久水蜜桃av免费网站| 国产精品私人影院| 美女被久久久| 亚洲福利视频一区| 欧美日韩免费看| 亚洲欧美日韩一区二区三区在线| 这里只有精品丝袜| 欧美日韩精品免费 | 午夜亚洲激情| 亚洲色无码播放| 老司机午夜精品|