Git收入即学习

git远程操作: git push, git fetch, gi

2019-01-13  本文已影响0人  lzhenboy

  工作中使用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

参考文献:

Git远程操作详解

上一篇下一篇

猜你喜欢

热点阅读