Git分支操作
- 本地倉庫
- 創建分支
- 合并分支
- 刪除分支
- 遠程倉庫
- push 推送遠程分支
- pull 拉取遠程分支
- fetch 更新遠程分支
- 本地分支與遠程分支的跟蹤關系
本地倉庫
由于Git
的分布式特性,所以沒有絕對的本地和遠程概念,一切都是相對的。對于分支的操作,個人認為其實重點在于本地的分支操作,而對于遠程倉庫的分支操作歸結起來只有 推送
和 拉取
創建分支
創建本地分支有兩種命令方式,第一是使用分支命令branch
,第二是使用查看命令checkout
推薦使用查看命令 :git checkout -b <new_branch_name>
,它是下面兩條命令的簡寫
git branch <new_branch_name>
git checkout <new_branch_name>
深度應用,在某個場景下,當我們的項目在不斷推進后,老板突然說:“第一版其實還不錯,我們再看一下”,我:“…”。
這時我們當然可以使用回滾或者查看歷史版本的方式,在這之前先備份一下當前代碼,又或者創建個分支保護一下什么的,但是這樣做仍然可能會很危險,亦或者很麻煩,這個時候我們就會想,如果能在第一版有個分支就好了。是的,我們還可以根據某個歷史提交狀態來創建一個分支。
仍然使用查看命令git checkout -b <branch_name> <SHA-1>
,使用歷史提交版本的SHA-1校驗和來創建指定歷史版本的分支,SHA-1校驗和的值可以通過git log
查看,它實際上也是多個命令的簡寫
git checkout <SHA-1>
git branch <branch_name>
git checkout <branch_name>
git checkout -b
甚至可以根據遠程倉庫來創建本地分支,git checkout -b <local_branch> <remote>/<remote_branch>
說明:git branch
會根據當前的代碼狀態創建分支,不管這個狀態是最終狀態還是某個歷史狀態,git checkout
查看 / 切換分支,也可以查看某個歷史版本
除此之外,還能使用git checkout --orphan <branch_name>
創建一個空白分支
命令總結
git checkout -b <branch_name>
創建分支git checkout -b <branch_name> <SHA-1>
在歷史版本SHA-1位置創建分支git checkout -b <branch_name> <remote>/<remote_branch>
基于遠程分支創建分支git checkout --orphan <branch_name>
創建空白分支
合并分支
git提供了兩種合并指令 merge
和 rebase
,用于將兩個或兩個以上的開發歷史加入(合并)一起。如果合并沒有沖突,則會自動進行一次提交。
git merge <branch_name>
,將 branch_name 分支合并到當前分支
刪除分支
- 使用
git branch -d <branch_name>
來刪除指定分支,及時的刪除一些無用分支是個良好的習慣,不然我們將在眾多分支中暈頭轉向。 - 使用
git remote prune <remote>
來清除本地緩存的無效遠程分支指針
遠程倉庫
實際上并不存在顯性的對遠程分支的操作,所有對遠程分支的操作都是 push 的副作用。
對遠程倉庫的操作一般時 fetch,pull 和 push,這個操作的意義在于同步遠程倉庫和本地倉庫,更確切的說法是將本地倉庫的某條分支和遠程倉庫的某條分支進行同步。
比如本地倉庫有 master 和 test 兩條分支,遠程倉庫有 master 和 develop 兩條分支,我們可以將遠程倉庫的 develop 分支同步到本地的 master 分支上,也可以將本地的 master 分支同步到遠程倉庫的 master 分支上,同步的實質時合并兩條分支,如果是兩條不相關的分支,則不能合并,即推送 / 拉取不成功(強行推送 / 拉取除外)。
push 推送遠程分支
push的完整寫法是:
git push <remote> <local_branch>:<remote_branch>
意思是將本地 local_branch 分支推送到遠程倉庫的 remote_branch 分支,并進行 merge
合并,如果遠程倉庫沒有 remote_branch 分支則會創建分支,所以在遠程分支不存在的情況下,該操作相當于創建遠程分支
-
省略遠程分支名
git push <remote> <local_branch>
,git會推送local_branch分支到遠程倉庫的與本地分支同名的遠程分支
eg:git push origin dev
相當于git push origin dev:dev
的簡寫 -
省略本地分支名
git push <remote> :<remote_branch>
,Git會刪除遠程倉庫上的remote_branch分支,即用一個空分支更新remote_branch分支,相當于刪除遠程分支
eg:git push origin :dev
相當于git push origin --delete dev
-
省略所有分支名
git push <remote>
,如果當前分支和遠程分支存在追蹤關系,則本地分支和遠程分支都可以忽略。如果當前分支只有一個遠程主機,那么遠程主機也可以省略。 -
git push --all <remote>
將本地的所有分支都推送到遠程主機。 -
git push --force <remote> [<local_branch>:<remote_branch>]
當服務器上版本和本地版本不一致時,push會發生沖突,git會提示我們先使用pull來解決沖突,如果一定要推送,可以使用這個命令,除非一定要這樣,否則應該避免使用force。
pull 拉取遠程分支
和push類似,pull的完整寫法是(注意本地分支和遠程分支的順序):
git pull <remote> <remote_branch>:<loacl_branch>
意思是將遠程倉庫 remote_branch 分支拉取到本地倉庫的 local_branch 分支,并進行merge
合并,如果本地倉庫沒有 local_branch 分支則會創建分支。
-
省略本地分支名
git pull <remote> <remote_branch>
,git會拉取remote_branch分支當前本地分支 -
省略所有分支名
git pull <remote>
,如果當前分支和遠程分支存在追蹤關系,則本地分支和遠程分支都可以忽略。如果當前分支只有一個遠程主機,那么遠程主機也可以省略。 -
git pull <remote> --rebase
合并的時候采用rebase
模式
fetch 更新遠程分支
git pull
實際上是 git fetch
和 git merge
的聯合操作
git pull origin master
相當于
git fetch origin master
git merge origin/master
本地分支與遠程分支的跟蹤關系
git branch -vv
查看分支跟蹤情況git branch --set-upstream-to=<remote>/<branch_name> <branch_name>
將branch_name分支追蹤遠程分支remote/branch_namegit branch -u <remote>/<branch_name>
設置當前分支追蹤遠程分支 remote/branch_name