## 團隊Git 分支模型

名詞解釋:
1. `severe bug fixed for production hotfix 0.2`:為生產修補程序0.2修復的嚴重錯誤。
2. `incorporate bugfix in develop` 在開發中加入bugfix
3. `major features for next release`:下一版本的主要功能
4. `only bugfixes`:只有錯誤修正.
5. `bugfixes from release branch may be continuously merged back into develop`:發布分支的錯誤修正可能會不斷合并回到開發中
### 主分支
在核心部分,研發模型很大程度上靠現有模型支撐的。中心庫有2個可一直延續的分支
* master分支
* develop分支
每個Git用戶都要熟悉原始的master分支。與master分支并行的另一個分支,我們稱之為develop分支。
我們把原始庫/master庫認作為主分支,HEAD的源代碼存在于此版本中,并且隨時都是一個*預備**生產*狀態。
### 輔助性分支
我們的開發模型使用了各種輔助性分支,這些分支與關鍵分支(master和develop)一起,用來支持團隊成員們并行開發,使得易于追蹤功能,協助生產發布環境準備,以及快速修復實時在線問題。與關鍵分支不同,這些分支總是有一個有限的生命期,因為他們最終會被移除。
我們用到的分支類型包括:
* 功能分支
* 發布分支
* 熱修復分支
每一種分支有一個特定目的,并且受限于嚴格到規則,比如:可以用哪些分支作為源分支,哪些分支能作為合并目標。我們馬上將進行演練。
從技術角度來看,這些分支絕不是特殊分支。分支的類型基于我們使用的方法來進行分類。它們理所當然是普通的Git分支。
### 功能分支
可能是develop分支的分支版本,最終必須合并到develop分支中。
分支命名規則:除了`master、develop、release-*、hotfix-*`之外,[其他](http://www.wuseyun.com/htmldata/tag/50/%E5%85%B6%E4%BB%96.html)命名均可。
功能分支(有時被稱為topic分支)通常為即將發布或者未來發布版開發新的功能。當新功能開始研發,包含該功能的發布版本在這個還是[無](http://www.wuseyun.com/htmldata/tag/11/%E6%97%A0.html)法確定發布時間的。功能版本的實質是只要這個功能處于開發狀態它就會存在,但是最終會或合并到develop分支(確定將新功能添加到不久的發布版中)或取消(譬如一次令人失望的測試)。
功能分支通常存在于開發者的軟件庫,而不是在源代碼庫中。
#### 創建一個功能分支
開始一項功能的開發工作時,基于develop創建分支
```
$ git checkout -b DD_TASKID_381 develop
Switched to a new branch 'DD_TASKID_381'
```
> 本地分支最好按照項目需要命名 `DD_TASKID_381`,表示點點項目任務ID = 381
#### 在任務分支開發項目
這里開始編寫代碼(當前分支`DD_TASKID_381`),代碼編寫完后,查看被修改的文件
```
$ git status
On branch DD_TASKID_381
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: readme.md
no changes added to commit (use "git add" and/or "git commit -a")
```
#### 合并一個功能到develop分支
完成的功能可以合并進develop分支,以明確加入到未來的發布。切換到開發分支 `develop`
```
$ git checkout develop
Switched to branch 'develop'
```
合并`DD_TASKID_381`分支到 'develop'
```
$ git merge --no-ff DD_TASKID_381
Merge made by the 'recursive' strategy.
readme.md | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
```
>` no-ff`標志導致合并操作創建一個新commit對象,即使該合并操作可以`fast-forward`。這避免了丟失這個功能分支存在的歷史信息,將該功能的所有提交組合在一起
(如果功能開發完畢)刪除本地`DD_TASKID_381`分支
```
$ git branch -d DD_TASKID_381
Deleted branch DD_TASKID_381 (was b674d30).
```
推送本地`develop`分支遠程到`origin/develop`分支
```
$ git push origin develop
Enumerating objects: 6, done.
Counting objects: 100% (6/6), done.
Delta compression using up to 4 threads.
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 460 bytes | 92.00 KiB/s, done.
Total 4 (delta 3), reused 0 (delta 0)
To https://git.coding.net/Tinywan/juhepay-dev.git
19ef874..54dee6f develop -> develop
```
## 實踐步驟
* 開發、測試、正式全部使用docker不是環境
* (新人)每次從 `develop `開發分支拉取最新代碼,創建自己的分支:`git checkout -b tinywan develop
`編寫代碼
* 編寫好代碼后切換到 `develop`,在`develop`分支整合已經開發完成的特性 ,開發完成的特性必須合并到develop分支,即添加到即將發布的版本中。
```
git merge --no-ff tinywan
# 推送到遠程開發開發分支
git push origin develop
```
* jenkins開始構建。使用自己的賬戶在[http://jenkins.frp.tinywan.top](http://jenkins.frp.tinywan.top)上使用jenkins工具在任務[測試環境【develop分支】](#) 立即構建。在測試環境可以立即預覽修改的內容
* 告訴測試人員可以測試了
* 開發環境代碼發布到正式環境,主要就Tinywan負責。請在conding上手動[【新建合并請求】](https://coding.net/u/Tinywan/p/juhepay/git/compare)。合并開發分支到master分支上面
* jenkins開始構建。使用自己的賬戶在[http://jenkins.frp.tinywan.top](http://jenkins.frp.tinywan.top)上使用jenkins工具在任務[正式環境【master分支】(危險)】](#)
* 正式環境可以進行測試代碼了
- 序言
- 專題零 PHP基礎
- 1、線程安全與非線程(NTS)安全版本的區別
- 2、JWT認證
- 3、數組
- 專題一 Nginx 實踐教程
- 1、什么是Nginx?
- 2、Nginx 特性和編譯安裝
- 3、日志配置和模塊講解
- 4、靜態資源和緩存服務
- 5、正向和反向服務
- 6、七層和四層負載均衡
- HTTP負載均衡(七層)
- TCP負載均衡(四層)
- 阿里云負載均衡配置
- 7、Rewrite規則
- 8、如何配置HTTPS服務
- 9、高級模塊(RTMP)
- (1)nginx-vod-module 模塊
- 10、Nginx與Lua開發(Openresty介紹)
- 11、性能優化和常見問題
- 12、什么Openresty以及Openresty擴展模塊學習
- 13、實踐案例
- (1)限流模塊
- (2)詳解:Nginx 反向代理、后端檢測模塊
- 14、如何做一個systemctl服務
- (1)Centos
- 15、agentzh 的 Nginx 教程
- 16、Openresty-Lua動態修改upstream后端服務
- 17、16點搞定高性能web服務器
- 18、如何配置proxy_cache模塊
- 1、微信打開https頁面顯示空白解決記錄
- 19、在線 Nginx 配置生成器
- 20、Nginx的負載均衡算法
- 1、加權輪詢理論
- 專題二 流媒體系統
- 1、什么是視頻直播?
- 2、如何使用推流軟件OBS?
- 3、基于Nginx 的RTMP模塊搭建系統
- 4、直播流程
- 5、典型業務場景
- 6、解決方案架構
- 7、編寫Shell腳本上傳直播回顧到阿里云OSS存儲
- 8、直播回調授權觀看
- 9、視頻直播源如何加密
- 10、如何實現視頻在線云剪輯
- 11、視頻點播以及加密技術實現
- 12、FFmpeg使用
- 13、播放器
- 14、其他問題
- 15、HLS 直播加密播放
- 16、nginx-vod-module 模塊
- 17、車輛維修直播系統
- 專題三 Redis 數據庫
- 1、編譯安裝
- 2、配置詳解
- 3、基礎知識
- 4、Redis 執行Lua腳本基本用法
- 5、Redis 漏洞如何防止被黑客攻擊
- 6、使用場景
- 7、如何在Ubuntu 16.04上安裝和配置Redis
- 8、Redis實現分布式鎖(集群版)
- 9、Redis鍵空間通知
- 1strace 調試
- 10、Redis5.0 搭建Cluster集群
- 1、創建和使用Redis群集
- 2、新增節點
- 11、基于Redis的限流器的實現
- 12、Redis5.0 新特性
- 1、新的Stream類型
- 附錄一 常見問題
- 專題四 Shell 腳本
- 1、編寫快速安全Bash腳本的建議
- 2、寫好shell腳本的13個技巧
- 3、shell腳本實現分日志級別記錄日志
- 4、Nginx日志定時備份和刪除
- 5、SHELL腳本小技巧
- 6、Mysql 自動備份腳本安全加鎖機制
- 7、PHP和Shell 腳本如何很好的搭配
- 8、Shell 腳本判斷Redis鍵值是否是一個正整數
- 專題五 ThinkPHP5 框架
- 1、如何使用命令行(帶參數)
- 2、如何使用多任務隊列
- 3、緩存支持文件緩存和Redis緩存
- 4、通過redis實現session共享存儲 (不需要修改php.ini配置文件)
- 5、符合REST架構設計的API,提供便利的API的版本號訪問地址
- 6、引入Trait,實現了代碼的復用
- 7、結合GatewayWorker實現簡單的聊天功能
- 8、PHPExcel與ajax結合進行文件異步下載
- 9、phpspreadsheet 導出文件支持Excel、Csv、Html格式導出
- 10、讀取 Excel 上傳文件后批量導入MySQL數據庫
- 11、支付寶沙箱模式支付(無需商戶賬號)
- 12、自定義日志(模塊分類)和 socketlog-server服務
- 13、如何實現數據庫自定義自增字段實現,方法
- 14、分布式之延時任務方案解析
- (1)生成訂單60秒后,給用戶發短信
- (2)延遲自動取消訂單
- 15、Repository 模式實現業務邏輯和數據訪問的分離
- 16、命令行守護進程
- 17、如何自定義異常類
- (1)Exception 類
- (2)系統異常處理
- (3)自定義異常類
- (4)自定義異常類處理類
- (6)全局異常類處理
- 18、阿里云專題
- (1)如何使用短信SDK
- (2)OSS擴展使用
- 19、命令行
- 20、容器專題
- 21、緩存
- (1)緩存自動更新
- 22、日志
- (1)錯誤日志郵件通知
- (2)日志參數介紹
- 23、經典案例
- 1、API開發實現自動校驗參數
- 24、升級坑記錄
- 25、生產環境部署
- 1、開啟緩存
- 專題六 MySQL數據庫
- 1、安裝與配置
- 2、索引
- 3、字符集
- 4、導出導入數據
- 5、5.7版本兼容性
- 6、數據庫自動備份
- 7、優化
- 8、數據庫設計規范
- 附錄一 常用語句
- 附錄二 MySQL實戰45講
- 1、常用語解釋
- 專題七 PHP異常處理
- 第一章 Exception
- 第二章 系統異常處理
- 第三章 自定義異常類
- 第四章 自定義異常類處理類
- 第五章 日志
- 第六章 全局異常類處理
- 專題八 常用整理
- 第一章、Linux 命令
- 第二章、Google 擴展
- 第三章、frp內網穿透
- 【進階一】做成一個服務
- 【進階二】代理一個Websocket 服務
- 【進階三】代理N個Web服務
- 附錄一 Docker-compose 配置
- 第四章、如何美化文檔
- 第五章 如何提高訪問github的速度
- 第六章 Vultr搭建SS教程
- 第七章 VS code 環境配置
- 第八章、Ngrok
- 第十章 PHP7新特性
- 第十一章 PPH編譯安裝
- 第十二章 使用systemd管理workerman
- 第十三章 yaconf
- 第十四章 Supervisor進程管理工具
- 第十五章 常用工具列表
- 1、免費IP地址庫
- 第十六章 Ubuntu rc.local systemd設置
- 第十七章 技術人員擴展Web應用程序
- 附錄一 、Highcharts Ajax異步加載
- 附錄二 laydate詳細示例
- 第十八章 Redis配置Cookie模擬session登錄
- 專題九 PHP函數
- (1)系統函數
- (2)自定義函數
- (3)回調函數
- (4)匿名函數
- (5)遞歸函數
- (6)常用函數庫
- (7)call_user_func函數
- 專題十 問題誤區
- 1 - 跨域問題
- 2 - PHP 面試總結
- 3、PHP算法
- 4、MySQL基礎知識
- 5、面試總結
- 6、empty、isset、is_null的用法和區別
- 7、PHP常用函數整理
- 8、Git 注意要點
- 1、git 解決每次更新代碼都要輸入用戶名密碼
- 2、git stash和git stash pop
- 3、分支(OEM管理)
- 4、推送本地分支到遠程分支
- 5、Git分支模型
- 9、PHP常見誤區
- 10、shell 腳本
- 11、Http 狀態嗎
- 12、日期、時間
- 13、it set 'X-Frame-Options' to 'DENY'
- 14、一次Redis內存占用很高
- 15、項目composer.lock 文件是否需要版本控制
- 專題十一 支付
- 一、return_url和notify_url的區別
- 二、匯付寶網關
- 三、PV、UV、IP 區別
- 四、支付結算周期
- 五、ngrok
- 六、轉賬
- 七、支付寶
- 1、當面付
- (1)條碼支付和掃碼支付介紹
- (2)接口申請
- (3)生成RSA密鑰
- (4)SDK集成與密鑰配置
- (5)掃碼支付接入
- 2、常見錯誤信息
- 3、商家服務
- 4、企業支付
- 5、第三方應用
- 6、服務商接入
- 7、訂單查詢
- 8、新轉賬鏈接來生成收款碼
- 9、銀行卡轉賬
- 八、三方渠道
- 九、結算
- 十、在線支付平臺的實現
- 1、支付平臺的接入
- 2、支付請求、支付結果返回的傳輸安全
- 3、支付站點、商戶站點、銀行網關的交互
- 4、支付狀態不同步的處理
- 5、支付方案
- (1)銀行對接方案
- 十一、在線支付平臺支付接口的設計
- 1、支付接口
- (1)支付請求參數
- (2)支付返回參數
- 2、退款接口
- 3、查詢接口
- 遇到的坑
- 1、異步和主查詢遇到的問題
- 2、一次沒有記錄的訂單是如何代付成功的?
- 十二、個人免簽支付
- 專題十二 安全
- 1、SQL注入
- 2、XSS攻擊
- 3、會話固定
- 4、會議捕獲和劫持
- 5、跨站點請求偽造(CSRF)
- 6、代碼注入
- 7、RSA 加密解密
- 8、PHP處理密碼的幾種方式
- 9、安全建議
- 10、Shell腳本加密工具——Shc
- 12、DDos攻擊
- 11、RSA 1024和AES 256
- (1)RSA加密傳輸代碼示例
- (2) 支付Demo
- 附錄一 一次阿里云被Doss
- 專題十三 消息中間件(MQ)
- 消息一、NSQ
- 消息二、分布式之消息隊列
- 1、為什么要使用消息隊列 ?
- 消息三、RabbitMQ
- 4、消息確認機制
- 1、 簡單隊列 hello world
- 專題十四 Docker
- 第一部分 Docker安裝
- 第二部分 如何在本地構建鏡像
- 第三部分 鏡像、容器以及命令操作
- 1、進入容器的4種方式
- 第四部分 Dockerfile指令介紹
- 第五部分 發布自己的鏡像
- 第六部分 數據卷管理
- 第七部分 Docker-compose
- 1、Docker-Compose入門基礎
- 2、構建自己的docker-compose配置
- 第八部分 Docker網絡
- 第九部分 搭建私有倉庫
- 第十部分 Docker部署方式
- 第十一部分 Swarm集群
- 1、Swarm介紹
- 2、Swarm集群部署與管理
- 1、命令列表
- 2、創建集群
- 3、為swarm添加節點
- 3、集群服務管理
- 1、部署服務
- 2、檢查服務
- 3、擴展服務
- 4、刪除服務
- 5、更新服務
- 6、清空節點
- 4、管理應用程序數據(數據持久化)
- 5、集群服務發布
- 6、服務發現與負載均衡(上)
- 7、服務發現與負載均衡(下)
- 8、高可用架構
- 9、服務配置文件管理
- 10、集群部署LNMP網站平臺實戰
- 附錄一 基礎
- 附錄二 常見錯誤問題
- 1、設置時區時間
- 附錄三 阿里云部署記錄
- 附錄四 Ubuntu 18.04換國內源
- 附錄五 常見文件精粹
- 附錄六 Kong
- 附錄七 PHPStrom 調試XDebug
- 附錄八 Docker和PHP
- 附錄九 安裝RabbitMQ
- 1、使用場景
- 2、簡單隊列
- 3、交換機模式
- 4、插件安裝
- 專題十五 Git版本管理
- 1、Git基礎命令
- 2、團隊Git 分支模型
- 3、緩存&撤銷
- 4、儲藏與清理
- 5、生成SSH公鑰
- 6、配置 Git
- 附錄一 常見誤區
- 附錄二、如何同步Fork
- 附錄三 通過烏龜查看歷史記錄
- 附錄四 多Git賬戶id_rsa私鑰
- 專題十六 WorkerMan
- 1、Worker類的使用
- 2、AsyncTcpConnection類
- 3、SocketIO消息推送
- 4、ThinkPHP5.1使用
- 附錄一 使用systemd管理workerman
- 專題十七 Jenkins
- 1、Jenkins安裝
- 2、Pipeline插件
- 3、BlueOcean
- 附錄一 常見錯誤
- 附錄二 實戰一
- 專題十八 測試專題
- API接口
- 第一章:如何調用API接口
- 第二章:如何創建推流地址
- 網絡狀態碼大全
- 測試記錄
- 筆記一:Nginx-Rtmp推流授權
- 筆記二:阿里直播推流筆記
- 筆記三:私有云直播推流筆記
- 筆記四:IM 測試記錄
- 項目功能列表
- 功能一:生成短鏈接網址
- LiveVideoStack
- 音視頻未來
- AV1
- JavaScript
- 基礎知識
- Unix/C編程
- 1、基本概念
- 2、Unix套接字
- 二、Crontab
- 1、入門教程
- 2、crontab 解決周期內未執行完重復執行
- Golang
- 一、基礎
- 二、命令行
- 自動部署持續集成
- 1、利用WebHook實現PHP自動部署Git代碼
- 2、coding托管你的Gitbook
- 3、OneinStack
- 4、利用 GitHook 構建持續交付和部署
- 并發
- 第一章、訂單并發處理
- 第二章、分布式鎖
- 設計模式
- 第一章、依賴注入
- 第二章、策略模式
- 第三章、裝飾器模式
- 第四章、Service模式
- 第五章、Repository模式
- 第六章、Presenter模式
- 創建設計模式
- 單例模式(Singleton)
- 工廠模式(Factory)
- 抽象工廠模式(AbstractFactory)
- 建造者模式(Builder)
- 原型模式(Prototype)
- 結構設計模式
- 適配器模式(Adapter)
- 橋接模式(Bridge)
- 合成模式(Composite)
- 裝飾器模式(Decorator)
- 門面模式(Facade)
- 代理模式(Proxy)
- 享元模式(Flyweight)
- 常用
- 1、編輯器
- 2、編譯安裝
- 3、生成二維碼(qr-code)
- 5、Mysql
- 4、Composer
- 6、看云美化CSS樣式
- 7 office2019激活方法
- MVC
- 第一章、MVC 框架中的路由器(Router)是如何跑起來的?
- 專題十五 區塊鏈
- 1、區塊鏈到底長什么樣?
- 面試招聘
- 專題十六 PHPstrom工具
- 附錄一 采坑記錄
- 1、 Redis錯誤 No space left on device
- 個人簡歷
- PHP高級實戰
- 1、自動加載
- ThinkPHp3.2
- 1、四種URL_MODEL模式
- 沃土