工作中使用git来管理项目的小伙伴是不是会频繁地使用git的远程操作,下面是我对git在本地仓库与远程仓库之间进行交互的三个常用命令:git push,git fetch,git pull 进行了整理和总结,希望对大家有所帮助。
欢迎大家前来交流讨论,不足之处,请指出,谢谢!
git push
1. 推送本地分支到远程分支
git push <远程主机名> <本地分支名>:<远程分支名>
2. 如果省略远程分支名,则表示将本地分支推送至与之存在“追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建:
git push origin master
上述命令表示:将本地master分支推送到origin主机的master分支。如果后者不存在,则会被新建。
3. 如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。
git push origin :master
等价于:
git push origin --delete master (删除远程分支)
4. 如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。
git push origin
5. 如果当前分支只有一个追踪分支,那么主机名都可以省略:
git push
git fetch
1. 将远程主机所有更新全部取回到本地
git fetch <远程主机名>
2. 将远程主机特定分支更新取回到本地
git fetch <远程主机名> <远程分支名>
注:所取回的更新,在本地主机上要用“远程主机名/分支名”的形式读取。如origin主机的master,就要用origin/master读取。
(1) 可以在此origin/master的基础上创建新的分支:
git checkout -b newBranch origin/master
(2) 也可以将此origin/master分支合并到本地分支:
git merge origin/master
git pull
1. 取回远程主机某个分支的更新,再与本地指定分支合并
git pull <远程主机名> <远程分支名>:<本地分支名>
eg:取回origin主机的next分支与本地master分支合并:
git pull origin next:master
2. 如果远程分支是与当前分支合并,则冒号后面的部分可以省略:
git pull origin next
等价于:
git fetch origin next
git merge origin/next
注:
在某些场合,Git会自动在本地分支与远程分支之间建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支建立追踪关系。也就是说,本地的master分支自动“追踪”origin/master分支。
Git也允许手动建立追踪关系:
eg:指定本地分支master追踪远程origin/next分支:
git branch --set-upstream-to origin/next master
注:查看分支追踪关系:
git branch -vv
3. 如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分机名
git pull origin
上面命令表示,本地的当前分支自动与对应的origin主机“追踪分支”(remote-tracking branch)进行合并。
4. 如果当前分支只有一个追踪分支,连远程主机名都可以省略
git pull
注:
如果远程主机删除了某个分支,默认情况下,git pull不会在拉取远程分支的时候删除对应的本地分支。这是为了防止,由于其他人操作了远程主机,导致git pull不知不觉删除了本地分支。
但可以通过加参数 -p 就会在本地删除远程已经删除的分支:
git pull -p