Git分支操作与远程仓库的使用
Git分支操作
- 本地倉(cāng)庫(kù)
- 創(chuàng)建分支
- 合并分支
- 刪除分支
- 遠(yuǎn)程倉(cāng)庫(kù)
- push 推送遠(yuǎn)程分支
- pull 拉取遠(yuǎn)程分支
- fetch 更新遠(yuǎn)程分支
- 本地分支與遠(yuǎn)程分支的跟蹤關(guān)系
本地倉(cāng)庫(kù)
由于Git的分布式特性,所以沒有絕對(duì)的本地和遠(yuǎn)程概念,一切都是相對(duì)的。對(duì)于分支的操作,個(gè)人認(rèn)為其實(shí)重點(diǎn)在于本地的分支操作,而對(duì)于遠(yuǎn)程倉(cāng)庫(kù)的分支操作歸結(jié)起來只有 推送 和 拉取
創(chuàng)建分支
創(chuàng)建本地分支有兩種命令方式,第一是使用分支命令branch,第二是使用查看命令checkout
推薦使用查看命令 :git checkout -b <new_branch_name>,它是下面兩條命令的簡(jiǎn)寫
git branch <new_branch_name> git checkout <new_branch_name>深度應(yīng)用,在某個(gè)場(chǎng)景下,當(dāng)我們的項(xiàng)目在不斷推進(jìn)后,老板突然說:“第一版其實(shí)還不錯(cuò),我們?cè)倏匆幌隆?#xff0c;我:“…”。
這時(shí)我們當(dāng)然可以使用回滾或者查看歷史版本的方式,在這之前先備份一下當(dāng)前代碼,又或者創(chuàng)建個(gè)分支保護(hù)一下什么的,但是這樣做仍然可能會(huì)很危險(xiǎn),亦或者很麻煩,這個(gè)時(shí)候我們就會(huì)想,如果能在第一版有個(gè)分支就好了。是的,我們還可以根據(jù)某個(gè)歷史提交狀態(tài)來創(chuàng)建一個(gè)分支。
仍然使用查看命令git checkout -b <branch_name> <SHA-1>,使用歷史提交版本的SHA-1校驗(yàn)和來創(chuàng)建指定歷史版本的分支,SHA-1校驗(yàn)和的值可以通過git log查看,它實(shí)際上也是多個(gè)命令的簡(jiǎn)寫
git checkout <SHA-1> git branch <branch_name> git checkout <branch_name>git checkout -b甚至可以根據(jù)遠(yuǎn)程倉(cāng)庫(kù)來創(chuàng)建本地分支,git checkout -b <local_branch> <remote>/<remote_branch>
說明:git branch會(huì)根據(jù)當(dāng)前的代碼狀態(tài)創(chuàng)建分支,不管這個(gè)狀態(tài)是最終狀態(tài)還是某個(gè)歷史狀態(tài),git checkout 查看 / 切換分支,也可以查看某個(gè)歷史版本
除此之外,還能使用git checkout --orphan <branch_name>創(chuàng)建一個(gè)空白分支
命令總結(jié)
- git checkout -b <branch_name> 創(chuàng)建分支
- git checkout -b <branch_name> <SHA-1> 在歷史版本SHA-1位置創(chuàng)建分支
- git checkout -b <branch_name> <remote>/<remote_branch> 基于遠(yuǎn)程分支創(chuàng)建分支
- git checkout --orphan <branch_name> 創(chuàng)建空白分支
合并分支
git提供了兩種合并指令 merge 和 rebase,用于將兩個(gè)或兩個(gè)以上的開發(fā)歷史加入(合并)一起。如果合并沒有沖突,則會(huì)自動(dòng)進(jìn)行一次提交。
git merge <branch_name>,將 branch_name 分支合并到當(dāng)前分支
刪除分支
- 使用git branch -d <branch_name>來刪除指定分支,及時(shí)的刪除一些無用分支是個(gè)良好的習(xí)慣,不然我們將在眾多分支中暈頭轉(zhuǎn)向。
- 使用git remote prune <remote> 來清除本地緩存的無效遠(yuǎn)程分支指針
遠(yuǎn)程倉(cāng)庫(kù)
實(shí)際上并不存在顯性的對(duì)遠(yuǎn)程分支的操作,所有對(duì)遠(yuǎn)程分支的操作都是 push 的副作用。
對(duì)遠(yuǎn)程倉(cāng)庫(kù)的操作一般時(shí) fetch,pull 和 push,這個(gè)操作的意義在于同步遠(yuǎn)程倉(cāng)庫(kù)和本地倉(cāng)庫(kù),更確切的說法是將本地倉(cāng)庫(kù)的某條分支和遠(yuǎn)程倉(cāng)庫(kù)的某條分支進(jìn)行同步。
比如本地倉(cāng)庫(kù)有 master 和 test 兩條分支,遠(yuǎn)程倉(cāng)庫(kù)有 master 和 develop 兩條分支,我們可以將遠(yuǎn)程倉(cāng)庫(kù)的 develop 分支同步到本地的 master 分支上,也可以將本地的 master 分支同步到遠(yuǎn)程倉(cāng)庫(kù)的 master 分支上,同步的實(shí)質(zhì)時(shí)合并兩條分支,如果是兩條不相關(guān)的分支,則不能合并,即推送 / 拉取不成功(強(qiáng)行推送 / 拉取除外)。
push 推送遠(yuǎn)程分支
push的完整寫法是:
git push <remote> <local_branch>:<remote_branch>意思是將本地 local_branch 分支推送到遠(yuǎn)程倉(cāng)庫(kù)的 remote_branch 分支,并進(jìn)行 merge 合并,如果遠(yuǎn)程倉(cāng)庫(kù)沒有 remote_branch 分支則會(huì)創(chuàng)建分支,所以在遠(yuǎn)程分支不存在的情況下,該操作相當(dāng)于創(chuàng)建遠(yuǎn)程分支
-
省略遠(yuǎn)程分支名 git push <remote> <local_branch> ,git會(huì)推送local_branch分支到遠(yuǎn)程倉(cāng)庫(kù)的與本地分支同名的遠(yuǎn)程分支
eg:git push origin dev 相當(dāng)于 git push origin dev:dev 的簡(jiǎn)寫 -
省略本地分支名 git push <remote> :<remote_branch> ,Git會(huì)刪除遠(yuǎn)程倉(cāng)庫(kù)上的remote_branch分支,即用一個(gè)空分支更新remote_branch分支,相當(dāng)于刪除遠(yuǎn)程分支
eg:git push origin :dev 相當(dāng)于 git push origin --delete dev -
省略所有分支名 git push <remote> ,如果當(dāng)前分支和遠(yuǎn)程分支存在追蹤關(guān)系,則本地分支和遠(yuǎn)程分支都可以忽略。如果當(dāng)前分支只有一個(gè)遠(yuǎn)程主機(jī),那么遠(yuǎn)程主機(jī)也可以省略。
-
git push --all <remote> 將本地的所有分支都推送到遠(yuǎn)程主機(jī)。
-
git push --force <remote> [<local_branch>:<remote_branch>] 當(dāng)服務(wù)器上版本和本地版本不一致時(shí),push會(huì)發(fā)生沖突,git會(huì)提示我們先使用pull來解決沖突,如果一定要推送,可以使用這個(gè)命令,除非一定要這樣,否則應(yīng)該避免使用force。
pull 拉取遠(yuǎn)程分支
和push類似,pull的完整寫法是(注意本地分支和遠(yuǎn)程分支的順序):
git pull <remote> <remote_branch>:<loacl_branch>意思是將遠(yuǎn)程倉(cāng)庫(kù) remote_branch 分支拉取到本地倉(cāng)庫(kù)的 local_branch 分支,并進(jìn)行merge合并,如果本地倉(cāng)庫(kù)沒有 local_branch 分支則會(huì)創(chuàng)建分支。
-
省略本地分支名 git pull <remote> <remote_branch> ,git會(huì)拉取remote_branch分支當(dāng)前本地分支
-
省略所有分支名 git pull <remote> ,如果當(dāng)前分支和遠(yuǎn)程分支存在追蹤關(guān)系,則本地分支和遠(yuǎn)程分支都可以忽略。如果當(dāng)前分支只有一個(gè)遠(yuǎn)程主機(jī),那么遠(yuǎn)程主機(jī)也可以省略。
-
git pull <remote> --rebase 合并的時(shí)候采用rebase模式
fetch 更新遠(yuǎn)程分支
git pull 實(shí)際上是 git fetch 和 git merge 的聯(lián)合操作
git pull origin master相當(dāng)于
git fetch origin master git merge origin/master本地分支與遠(yuǎn)程分支的跟蹤關(guān)系
- git branch -vv 查看分支跟蹤情況
- git branch --set-upstream-to=<remote>/<branch_name> <branch_name> 將branch_name分支追蹤遠(yuǎn)程分支remote/branch_name
- git branch -u <remote>/<branch_name> 設(shè)置當(dāng)前分支追蹤遠(yuǎn)程分支 remote/branch_name
總結(jié)
以上是生活随笔為你收集整理的Git分支操作与远程仓库的使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Re:从零开始的Vue项目搭建
- 下一篇: Git 撤销操作 / 回滚历史