Git
Git Flow最常見的分支用
Master
主要是用來放系統穩定、上線的版本。
註記:這個分支的狀況,只能從別的分支合併過來,開發者絕對不會直接 Commit 到這個分支。
因為是穩定版本,通常也會在這個分支上的 Commit 上打上版本號標籤。
Develop
這個分支主要是所有開發的基礎分支,當要新增功能的時候,所有的 Feature 分支都是從這個分支切出去的。
註記:而 Feature 分支的功能完成後,也都會合併回來這個分支。
Hotfix
當線上產品發生緊急問題的時候,會從 Master 分支開一個 Hotfix 分支出來進行修復,Hotfix 分支修復完成之後,
會合併回 Master 分支,也同時會合併一份到 Develop 分支。
為什麼要合併回 Develop 分支?
如果不這麼做,等到時候 Develop 分支完成並且合併回 Master 分支的時候,那個問題就又再次出現了。
那為什麼一開始不從 Develop 分支切出來修?
因為 Develop 分支的功能可能尚在開發中,這時候硬是要從這裡切出去修再合併回 Master 分支,只會造成更大的災難。
Release
當認為 Develop 分支夠成熟了,就可以把 Develop 分支合併到 Release 分支,在這邊進行算是上線前的最後測試。
測試完成後,Release 分支將會同時合併到 Master 以及 Develop 這兩個分支上。
Master 分支是上線版本,而合併回 Develop 分支的目的,是因為可能在 Release 分支上還會測到並修正一些問題,
所以需要跟 Develop 分支同步,免得之後的版本又再度出現同樣的問題。
Feature
當要開始新增功能的時候,就是使用 Feature 分支的時候了。
Feature 分支都是從 Develop 分支來的,完成之後會再併回 Develop 分支。
切割方式會是如下
如果有bug 從Mater 開一個HotFix分支,改完合併到develop和Mater上
參考資源:https://ithelp.ithome.com.tw/articles/10227605
元哥的筆記