git fetch和git pull都可以將遠端倉庫更新至本地那么他們之間有何區(qū)別?想要弄清楚這個問題有有幾個概念不得不提。
推薦(免費):Git
FETCH_HEAD: 是一個版本鏈接,記錄在本地的一個文件中,指向著目前已經從遠程倉庫取下來的分支的末端版本。
commit-id:在每次本地工作完成后,都會做一個git commit 操作來保存當前工作到本地的repo, 此時會產生一個commit-id,這是一個能唯一標識一個版本的序列號。 在使用git push后,這個序列號還會同步到遠程倉庫。
有了以上的概念再來說說git fetch
git fetch:這將更新git remote 中所有的遠程倉庫所包含分支的最新commit-id, 將其記錄到.git/FETCH_HEAD文件中
git fetch更新遠程倉庫的方式如下:
git fetch origin master:tmp //在本地新建一個temp分支,并將遠程origin倉庫的master分支代碼下載到本地temp分支 git diff tmp //來比較本地代碼與剛剛從遠程下載下來的代碼的區(qū)別 git merge tmp //合并temp分支到本地的master分支 git branch -d temp //如果不想保留temp分支 可以用這步刪除
(1)如果直接使用git fetch,則步驟如下:
- 創(chuàng)建并更新本 地遠程分支。即創(chuàng)建并更新origin/xxx 分支,拉取代碼到origin/xxx分支上。
- 在FETCH_HEAD中設定當前分支-origin/當前分支對應,如直接到時候git merge就可以將origin/abc合并到abc分支上。
(2)git fetch origin
只是手動指定了要fetch的remote。在不指定分支時通常默認為master
(3)git fetch origin dev
指定遠程remote和FETCH_HEAD,并且只拉取該分支的提交。
git pull : 首先,基于本地的FETCH_HEAD記錄,比對本地的FETCH_HEAD記錄與遠程倉庫的版本號,然后git fetch 獲得當前指向的遠程分支的后續(xù)版本的數(shù)據(jù),然后再利用git merge將其與本地的當前分支合并。所以可以認為git pull是git fetch和git merge兩個步驟的結合。
git pull的用法如下:
git pull <遠程主機名> <遠程分支名>:<本地分支名> //取回遠程主機某個分支的更新,再與本地的指定分支合并。
因此,git fetch是從遠程獲取最新版本到本地,但不會自動merge。
而git pull則是會獲取所有遠程索引并合并到本地分支中來。效果相同時git pull將更為快捷。