本篇文章講解了Git的一些基本的團隊協作命令,和GitFlow工作流指南
1.開分支
git branch 新分支名
例如,在master分支下,新開一個開發分支:
git branch dev
2.切換到新分支
git checkout 分支名
例如,在master分支下,切換到新開的dev:
git checkout dev
3.開分支和切換分支合並到一個命令
git checkout -b 新分支名
例如,新開一個開發分支,並立即切換到該分支:
git checkout -b dev
4.切換回原分支
git checkout 原分支名
例如,切換回master
git checkout master
注意:當前分支有修改,還未commit的時候,會切換失敗,應當先commit,但可以不用push
5.合並分支
git merge 需要合並的分支名
例如,剛剛已經切換回master,現在需要合並dev的內容:
git merge dev
建議在GitLab(或者其他git系統)上面創建merge request的形式來進行分支的合並和代碼審核。
6.查看本地分支列表
git branch -a
前面帶remotes/origin 的,是遠程分支
7.查看遠程分支列表
git branch -r
8.向遠程提交本地新開的分支
git push origin 新分支名
例如,剛剛在master下新開的dev分支:
git push origin dev
9.刪除遠程分支
git push origin :遠程分支名
例如,刪除剛剛提交到遠程的dev分支:
git push origin :dev
10.刪除本地分支
git branch 分支名稱 -d
例如,在master分支下,刪除新開的dev分支:
git branch dev -d
注意:如果dev的更改,push到遠程,在GitLab(或者其他git系統)上面進行了merge操作,但是本地master沒有pull最新的代碼,會刪除不成功,可以先git pull origin master,或者強制刪除
git branch dev -D
11.更新分支列表信息
git fetch -p
12.TortoiseGit(烏龜git)
不可否認,在windows下,這個是個不錯的工具。不管你是命令行新手還是重度使用者,我覺得都可以嘗試一下。
在你開始閱讀之前,請記住:流程應被視作為指導方針,而非“鐵律”。我們只是想告訴你可能的做法。因此,如果有必要的話,你可以組合使用不同的流程
Gitflow工作流定義了一個圍繞項目發布的嚴格分支模型。雖然比功能分支工作流復雜幾分,但提供了用於一個健壯的用於管理大型項目的框架。
Gitflow工作流沒有用超出功能分支工作流的概念和命令,而是為不同的分支分配一個很明確的角色,並定義分支之間如何和什麼時候進行交互。除了使用功能分支,在做准備、維護和記錄發布也使用各自的分支。當然你可以用上功能分支工作流所有的好處:Pull Requests、隔離實驗性開發和更高效的協作。
Gitflow工作流仍然用中央倉庫作為所有開發者的交互中心。和其它的工作流一樣,開發者在本地工作並push分支到要中央倉庫中。
相對使用僅有的一個master分支,Gitflow工作流使用2個分支來記錄項目的歷史。master分支存儲了正式發布的歷史,而develop分支作為功能的集成分支。這樣也方便master分支上的所有提交分配一個版本號。
剩下要說明的問題圍繞著這2個分支的區別展開。
每個新功能位於一個自己的分支,這樣可以push到中央倉庫以備份和協作。但功能分支不是從master分支上拉出新分支,而是使用develop分支作為父分支。當新功能完成時,合並回develop分支。新功能提交應該從不直接與master分支交互。
注意,從各種含義和目的上來看,功能分支加上develop分支就是功能分支工作流的用法。但Gitflow工作流沒有在這裡止步。
一旦develop分支上有了做一次發布(或者說快到了既定的發布日)的足夠功能,就從develop分支上fork一個發布分支。新建的分支用於開始發布循環,所以從這個時間點開始之後新的功能不能再加到這個分支上 —— 這個分支只應該做Bug修復、文檔生成和其它面向發布任務。一旦對外發布的工作都完成了,發布分支合並到master分支並分配一個版本號打好Tag。另外,這些從新建發布分支以來的做的修改要合並回develop分支。
使用一個用於發布准備的專門分支,使得一個團隊可以在完善當前的發布版本的同時,另一個團隊可以繼續開發下個版本的功能。
這也打造定義良好的開發階段(比如,可以很輕松地說,『這周我們要做准備發布版本4.0』,並且在倉庫的目錄結構中可以實際看到)。
GitHub 教程系列文章:
GitHub 使用教程圖文詳解 http://www.linuxidc.com/Linux/2014-09/106230.htm
Git 標簽管理詳解 http://www.linuxidc.com/Linux/2014-09/106231.htm
Git 分支管理詳解 http://www.linuxidc.com/Linux/2014-09/106232.htm
Git 遠程倉庫詳解 http://www.linuxidc.com/Linux/2014-09/106233.htm
Git 本地倉庫(Repository)詳解 http://www.linuxidc.com/Linux/2014-09/106234.htm
Git 服務器搭建與客戶端安裝 http://www.linuxidc.com/Linux/2014-05/101830.htm
Git 概述 http://www.linuxidc.com/Linux/2014-05/101829.htm
分享實用的GitHub 使用教程 http://www.linuxidc.com/Linux/2014-04/100556.htm
更多詳情見請繼續閱讀下一頁的精彩內容: http://www.linuxidc.com/Linux/2015-01/111999p2.htm