小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

關(guān)于SVN 目錄結(jié)構(gòu)

 命運(yùn)之輪 2013-01-22

   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為主開(kāi)發(fā)目錄,branches為分支開(kāi)發(fā)目錄,tags為tag存檔目錄(不允許修改)。但是具體這幾個(gè)目錄應(yīng)該如何使 用,svn并沒(méi)有明確的規(guī)范,更多的還是用戶自己的習(xí)慣。
    對(duì)于這幾個(gè)開(kāi)發(fā)目錄,一般的使用方法有兩種。我更多的是從軟件產(chǎn)品的角度出發(fā) (比如freebsd),因?yàn)榛ヂ?lián)網(wǎng)的開(kāi)發(fā)模式是完全不一樣的。
第一種方法,使用trunk作為主要的開(kāi)發(fā)目錄。
    一般的,我們的所有的開(kāi) 發(fā)都是基于trunk進(jìn)行開(kāi)發(fā),當(dāng)一個(gè)版本/release開(kāi)發(fā)告一段落(開(kāi)發(fā)、測(cè)試、文檔、制作安裝程序、打包等)結(jié)束后,代碼 處于凍結(jié)狀態(tài)(人為規(guī)定,可以通過(guò)hook來(lái)進(jìn)行管理)。此時(shí)應(yīng)該基于當(dāng)前凍結(jié)的代碼庫(kù),打tag。當(dāng)下一個(gè)版本/階段的開(kāi)發(fā)任務(wù)開(kāi)始,繼續(xù)在trunk 進(jìn)行開(kāi)發(fā)。此時(shí),如果發(fā)現(xiàn)了上一個(gè)已發(fā)行版本(Released Version)有一些bug,或者一些很急迫的功能要求,而正在開(kāi)發(fā)的版本(Developing Version)無(wú)法滿足時(shí)間要求,這時(shí)候就需要在上一個(gè)版本上進(jìn)行修改了。應(yīng)該基于發(fā)行版對(duì)應(yīng)的tag,做相應(yīng)的分支(branch)進(jìn)行開(kāi)發(fā)。例 如,剛剛發(fā)布1.0,正在開(kāi)發(fā)2.0,此時(shí)要在1.0的基礎(chǔ)上進(jìn)行bug修正。
按照時(shí)間的順序

  1. 1.0開(kāi)發(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 開(kāi)始開(kāi)發(fā),trunk此時(shí)為2.0的開(kāi)發(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開(kāi)發(fā),在trunk進(jìn)行2.0開(kāi)發(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)的開(kāi)發(fā)模 式,很多的公司都是采用這種模式進(jìn)行開(kāi)發(fā)的。trunk永遠(yuǎn)是開(kāi)發(fā)的主要目錄。

    第二種方法,在每一個(gè)release的branch中進(jìn)行 各自的開(kāi)發(fā),trunk只做發(fā)布使用。這種開(kāi)發(fā)模式當(dāng)中,trunk是不承擔(dān)具體開(kāi)發(fā)任務(wù)的,一個(gè)版本/階段的開(kāi)發(fā)任務(wù)在開(kāi)始的時(shí)候,根據(jù)已經(jīng) release的版本做新的開(kāi)發(fā)分支,并且基于這個(gè)分支進(jìn)行開(kāi)發(fā)。還是舉上面的例子,這里面的時(shí)序關(guān)系是。

  1. 1.0開(kāi)發(fā),做 dev1.0的branch
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
    +trunk/ (不擔(dān)負(fù)開(kāi)發(fā)任務(wù) )
    +branches/
        +dev_1.0 (copy from trunk)
    +tags/
  2. 1.0開(kāi)發(fā)完成,merge dev1.0到trunk
    此時(shí)的目 錄結(jié)構(gòu)
    svn://proj/
    +trunk/ (merge from branch dev_1.0)
    +branches/
         +dev_1.0 (開(kāi)發(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 (開(kāi)發(fā)任務(wù)結(jié)束,freeze)
    +tags/
        +tag_release_1.0 (copy from trunk)
  4. 1.0開(kāi)發(fā),做dev2.0分支
    此時(shí)的目錄結(jié)構(gòu)
    svn://proj/
    +trunk/
    +branches/
        +dev_1.0 (開(kāi)發(fā)任務(wù)結(jié)束,freeze)
        +dev_2.0 (進(jìn)行2.0開(kāi)發(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開(kāi)發(fā))
    +tags/
        +tag_release_1.0 (copy from trunk)
  6. 選擇性的進(jìn)行代碼merge

    這其實(shí)是一種分散式的開(kāi)發(fā),當(dāng)各個(gè)部分相對(duì) 獨(dú)立一些(功能性的),可以開(kāi)多個(gè)dev的分支進(jìn)行開(kāi)發(fā),這樣各人/組都不會(huì)相互影響。比如dev_2.0_search和dev_2.0_cache 等。但是這樣merge起來(lái)就是一個(gè)很痛苦的事情。

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

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

      其實(shí),這里并沒(méi)有一定之規(guī),更多的時(shí)候是兩種 模式結(jié)合使用。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多