分支規範

来源:http://www.cnblogs.com/xuld/archive/2016/10/05/5932780.html
-Advertisement-
Play Games

一、目的 我們制定分支規範,意在實現以下目標: 二、主分支: master 主分支(master)用於存放最新的穩定版本。 正式發佈時:在主分支上創建標簽(tag)。如果發佈非常頻繁可以不加。 標簽的命名規範為:release-v版本號-日期(如 release-v0.0.1-20161010)。業 ...


一、目的

 我們制定分支規範,意在實現以下目標:

  1. 減少溝通成本:開發者可以很清晰地知道需要修改的代碼位於哪個分支。
  2. 減少 bug 隱患:避免因分支合併導致 bug。
  3. 維護線上穩定:通過一定的流程規範,保證線上代碼安全。
  4. 靈活:支持多版本同時開發、同時發佈。
  5. 簡潔:用最少的分支解決問題,避免反覆創建、合併分支,節約操作時間。

二、主分支: master

主分支(master)用於存放最新的穩定版本。

正式發佈時:在主分支上創建標簽(tag)。如果發佈非常頻繁可以不加。

標簽的命名規範為:release-v版本號-日期(如 release-v0.0.1-20161010)。業務項目可以不加版本號;框架、工具項目可以不加日期。

release-xx 分支:如果需要同時維護多個發佈版本(比如有些框架在發佈新版同時還會更新老版),則需要基於 master 分支創建名為 release-v版本號首碼(如 release-v1.x)的分支,之後 master 分支持續更新為最新穩定版,release-xx 分支則持續更新為對應版本的最新穩定版。所有 release-xx 分支和 master 分支地位相同,master 相當於是 release-latest 分支。

三、開發分支: dev-xx

dev 分支用於存放最新代碼(可能包含未測試的代碼),只有需要正式發佈時才會合併到 master 分支。

如果項目對穩定性要求不高(比如小項目、練慣用的代碼),則可以不建 dev-xx 分支,而直接在 master 分支修改。

開發時:基於 master 分支創建名為 dev-v版本號(如 dev-v0.0.1)的分支。業務項目可以不加版本號,固定為 dev 分支。

開發完成後發佈測試:直接發佈 dev 分支到測試環境。如果測試出現 bug 則在 dev 分支繼續修複。

測試完成後正式發佈:將 dev 分支合併到 master 分支。然後發佈 master 分支。

如果需要同時開發多個版本,可以從 master 創建多個不同版本號的 dev-xx 分支。每次發佈後其它 dev-xx 分支需要從 master 分支合併最新的改動。

四、修複分支: bugfix-xx

發佈後線上發現 bug 時:

  • bug 影響不大:建議在 dev-xx 分支中修複,等待下次發佈時修複。
  • bug 影響很大:將線上代碼回滾到 master 分支的上一個標簽(或最近的 release-xx 分支)。
  • bug 影響一般:從 master 分支創建名為 bugfix-時間(如 bugfix-20161010190000) 的分支,在此分支修複 bug,修複完成後直接將 bugfix-xx 分支發佈上線。如果上線後 BUG 已解決則將 bugfix-xx 分支合併到 master 分支並刪除 bugfix-xx 分支。如果 bug 仍未解決,則繼續在此分支修複 bug 直到解決。

五、構建分支: build-xx

有些項目需要預編譯(壓縮、優化)代碼才能發佈上線,所有分支在發佈時都會先合併到同名的 build-xx 分支。

如 dev-0.0.1 在發佈測試環境時,需要先合併到 build-dev-0.0.1 分支,然後經過預編譯後發佈 build-dev-0.0.1 分支。

如 dev-0.0.1 在發佈正式環境時,需要先合併到 master 分支,然後合併到 build-master 分支,然後經過預編譯後發佈 build-master 分支。

build-xx 分支可以使用構建工具自動維護。大部分情況開發者不需要關心此分支,除非發現因自動構建導致的 bug 時,開發者可以切到此分支查找問題。

六、其它分支

根據項目實際需求,可以創建其它分支,如 github 頁面需要的 gh_pages 等分支。

七、總結

分支總共有:master、dev-xx、release-xx、bugfix-xx、build-xx 五類。大部分項目只需創建前面 2 個分支,其餘的根據需要再建。開發者平時只需維護 dev-xx 分支。dev-xx 的代碼只能發佈到測試環境,不能直接發佈上線。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、記憶體中的程式: 在進程被載入記憶體中時,基本上被分成許多小的節,以下是6個主要的節。 低地址 高地址 .text 節 .text節基本上相當於二進位可執行文件的.text部分,它包含了完成程式任務的機器指令。 該節標記為只讀,如果發生寫操作,會造成 segmentation fault。 在進程最 ...
  • 靜態代理 1、新建一個介面,這個介面所提供的方法是關於資料庫操作的 2、建一個目標類實現這個介面,這個目標類是我們要進行的業務 3、再建一個代理類,為目標對象提供一種代理,並以控制對這個對象的訪問。 由以上可知,代理模式的組成包括:目標介面(抽象角色),目標類(真實角色)和代理類(代理角色)。 4、 ...
  • Atitit 判斷判斷一張圖片是否包含另一張小圖片 1. keyword1 2. 模板匹配是在圖像中尋找目標的方法之一(切割+圖像相似度計算)1 3. 匹配效果2 4. 圖片相似度的演算法(感知哈希演算法”(Perceptual hash algorithm)2 5. 性能結果2 6. 如何提升性能3 ...
  • 本篇隨筆主要介紹 java 中 synchronized 關鍵字常用法,主要有以下四個方面: 1、實例方法同步 2、靜態方法同步 3、實例方法中同步塊 4、靜態方法中同步塊 我覺得在學習synchronized關鍵字之前,我們首先需要知道以下一點:Java 中每個實例對象對應一把鎖且每個實例對象只有 ...
  • 隨著 Asp.Net Mvc Core 發佈,給我的感覺,Microsoft(微軟) 一下子成了依賴註入的使用的瘋狂者,因為在我的印象中,依賴註入(Ioc DI)是業務程式員寫業務代碼時常用的,但像 Microsoft(微軟)把這個設計模式應用到了 Platform or Framework 上,這 ...
  • gitignore 應該包含 5 塊內容: 以下是 NODEJS 項目的 .gitignore 模板: ...
  • 目前根據習慣和創作時間,單元測試和源文件的代碼都是分開的。 是否可以考慮將它們放在一起: 好處: 可以很清晰地知道哪些文件缺少測試。 可以快速在源文件和單元測試文件之間跳轉,而不需要切換文件夾。 遵循了需要一起修改的代碼放在一起的原則,方便修改源碼時同步修改單元測試文件。 在移動、拷貝源碼時可以輕鬆 ...
  • atitit.日期,星期,時候的顯示方法ISO 8601標準 1. ISO 86011 2. DAte日期的顯示1 2.1. Normal1 2.2. 順序日期表示法(可以將一年內的天數直接表示)1 2.3. 星期顯示法(可以用2位數表示年內第幾個日曆星期,再加上一位數表示日曆星期內第幾天)2 3. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...