1. 程式人生 > >使用svn開發,目錄的約定與開發流程

使用svn開發,目錄的約定與開發流程

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的時候很麻煩,容易死人。


相關推薦

使用svn開發目錄約定開發流程

Subversion有一個很標準的目錄結構,是這樣的。 比如專案是proj,svn地址為svn://proj/,那麼標準的svn佈局是 svn://proj/ | +-trunk +-branches +-tags 這是一個標準的佈局,trunk為主開發目錄,branch

使用svn開發目錄管理的約定開發流程

領航科技-廣州網站建設、深圳網站建設、網站業務合作、做網站、廣州網站開發、深圳網站開發、小程式開發、APP開發、綜合網際網路專案技術合作,www.linghangtech.com , wx:HEB_137。 Subversion有一個很標準的目錄結構,是這樣的。 比如專案是proj,svn地址為

thinkphp5學習(一)——thinkphp5的目錄結構開發規範

控制 配置 helper ole url database 數據 tab 工具配置 開發規範: 目錄和文件 目錄使用小寫+下劃線; 類庫、函數文件統一以.php為後綴; 類的文件名均以命名空間定義,並且命名空間的路徑和類庫文件所在路徑一致; 類文件采用駝峰法命名(首字母大

基於WEB的教職工健康檔案管理系統java設計開發

**基於WEB的教職工健康檔案管理系統,java設計與開發** 基於WEB的教職工健康檔案管理系統mysql資料庫建立語句 基於WEB的教職工健康檔案管理系統oracle資料庫建立語句 基於WEB的教職工健康檔案管理系統sqlserver資料庫建立語句 基於WEB的

基於JSP的房屋出租管理系統系統設計java設計開發

**基於JSP的房屋出租管理系統系統設計,java設計與開發** 基於JSP的房屋出租管理系統系統設計mysql資料庫建立語句 基於JSP的房屋出租管理系統系統設計oracle資料庫建立語句 基於JSP的房屋出租管理系統系統設計sqlserver資料庫建立語句 基於

(轉)python 全棧開發Day75(DjangoAjax,檔案上傳,ajax傳送json資料,基於Ajax的檔案上傳,SweetAlert外掛)

昨日內容回顧 基於物件的跨表查詢 正向查詢:關聯屬性在A表中,所以A物件找關聯B表資料,正向查詢 反向查詢:關聯屬性在A表中,所以B物件找A物件,反向查詢 一對多: 按欄位:xx book --

基於WEB的網路遠端作業處理系統之使用者介面的設計實現java設計開發

**基於WEB的網路遠端作業處理系統之使用者介面的設計與實現,java設計與開發** 基於WEB的網路遠端作業處理系統之使用者介面的設計與實現mysql資料庫建立語句 基於WEB的網路遠端作業處理系統之使用者介面的設計與實現oracle資料庫建立語句 基於WEB的網路遠端

棋牌遊戲開發網絡遊戲開發遊戲開發小能手遊戲APP開發創業項目

logs style 電腦 應該 一個用戶 科技 麻將 小時 朋友 隨著生活節奏的加快和工作壓力的不時增加。越來越多的人處於工作、家庭、社會等各個方面壓力的夾層中,於是各種各樣的減壓方法湧現出來,玩遊戲早已經成為人們休閑娛樂的最佳選擇,但是遊戲的種類數不勝數,這也讓很多人絞

區塊鏈商城開發深圳區塊鏈開發區塊鏈虛擬貨幣技術開發公司

運用 公益 區塊鏈 中心 研究 未來 技術開發 商城 公司 區塊鏈時代已經到來,深圳區塊鏈開發公司 萬通互通公司提供區塊鏈開發技術,在如今這個消息泛濫的網絡時代,機會瞬息萬變,看到趨勢,抓住趨勢才能不被這個社會淘汰,區塊鏈是未來的趨勢。 區塊鏈技術也

深圳區塊鏈商城開發區塊鏈商城開發區塊鏈資產交易系統開發

時間 上傳 領域 狀態 獨立 區塊鏈技術 不可 合約 商城系統 深圳區塊鏈商城開發,區塊鏈商城開發,區塊鏈資產交易系統開發。 區塊鏈實際是一個跨學科,跨領域的復合型前沿技術,運用非常廣泛。 復合型前沿技術是指:分布式存儲及代碼是計算機,P2P網絡是社會

深圳區塊鏈商城開發深圳區塊鏈開發深圳區塊鏈商城開發技術

領導 是什麽 增長 共識機制 才會 一個人 部分 自動 價值 深圳區塊鏈商城開發,深圳區塊鏈開發,深圳區塊鏈商城開發技術是當前主流的技術,那麽,區塊鏈到底是什麽呢?深圳區塊鏈商城開發,深圳區塊鏈開發,深圳區塊鏈商城開發技術又是什麽呢? 狹義來講,區塊鏈是一種按照時間順序將數

專業的商城定制開發微分銷商城開發

分享 http 專業 分銷 技術 吸引 精細化運營 直播 銷量 漢全A6SHOP商城系統,一款觸手可及的企業商城,支持線上訂購,線下體驗。漢全A6SHOP商城系統助您輕松打造競爭力爆棚的企業商城 漢全A6SHOP商城系統實用產品: 促銷互動 將信息通過各種新奇的手段傳到

持幣生息系統開發會員管理系統開發貴州雲挖礦錢包系統開發

發的 架構 原理 進一步 開發技術 開發 工作 聊天 手機 持幣生息系統開發,會員管理系統開發,貴州雲挖礦錢包系統開發數字資產交易所開發,區塊鏈多幣種錢包開發,手機錢包開發,數字資產幣幣撮合交易平臺開發,場外OTC交易系統開發C2C交易網站開發,區塊鏈聊天社交直播系統開發,

區塊鏈多幣種錢包開發交易平臺開發抵押借貸平臺開發

Dapp開發 資產 一個 得到 正是 閑置 投資 區塊鏈 資金 區塊鏈在經歷交易平臺,公鏈,區塊鏈遊戲的熱潮之後,下一輪該輪到誰了呢?要知道,交易平臺是用戶交易,公鏈則是一個獨立的鏈條,區塊鏈遊戲則是挑起用戶的趣味心,接下來區塊鏈應該會走向何方呢?眾多人猜測,區塊鏈下一個風

多幣種錢包系統開發區塊鏈遊戲開發交易平臺開發

工具 區塊 很好 推廣 app 用戶 很多 交易平臺 目前 區塊鏈遊戲開發是現在很多企業利用區塊鏈技術研發出的一款具有趣味性的遊戲,這類型的遊戲大多以區塊鏈為底層技術而研發,目的就是能夠吸引用戶來關註這個遊戲。區塊鏈遊戲開發最早的應該是鏈克的玩客猴,用戶購買系統中的玩客猴,

多幣種錢包開發持幣生息系統開發抵押借貸系統開發

科技 說過 哪些 做的 使用 相對 交易 系統開發 風口 多幣種錢包是現在數字資產市場不可或缺的一種系統,因為它不僅僅是一個儲存幣的工具,還可以作為其他的用途。多幣種錢包不像單幣種錢包,它能夠儲存多個幣種,它就相當於一個錢包的集合體,讓用戶不再擔心需要下載多個系統才可以使用

類似plustoken錢包系統開發多幣種錢包開發

自己 模式 閑置 擔心 等等 什麽 出現 自動 聽說 了解數字資產錢包市場的用戶大概都聽說過plustoken,這款多幣種錢包中,除了擁有傳統的能夠多儲存數字資產的功能以外,還帶有智能狗自動搬磚的功能,用戶將數字資產存放在錢包系統裏面,開啟這一功能,在一定時間裏就能夠得到一

一對一直播原始碼和短視訊開發後直播平臺開發時代的兩匹快馬

隨著傳統一對多秀場直播間的人氣逐漸下滑,加上抖音APP全年的持續發力,富聊、v聊等一眾一對一視訊直播聊天平臺的出現,如今的直播平臺開發及運營有了更多的選擇,後直播平臺開發時代,我們的注意力不應當只侷限在送禮打賞這種傳統直播平臺盈利手段上,探索更多“直播+”及平臺運營模式至關重要,而一對一直播和短視訊平臺這兩匹

一對一直播源碼和短視頻開發後直播平臺開發時代的兩匹快馬

建立 過去的 同時 mar type .com 依靠 視頻內容 5g時代 隨著傳統一對多秀場直播間的人氣逐漸下滑,加上抖音APP全年的持續發力,富聊、v聊等一眾一對一視頻直播聊天平臺的出現,如今的直播平臺開發及運營有了更多的選擇,後直播平臺開發時代,我們的註意力不應當只局限