当前位置: 代码迷 >> 综合 >> git远程操作: git push, git fetch, git pull
  详细解决方案

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

热度:40   发布时间:2023-11-01 22:54:11.0

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

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

參考:
https://www.jianshu.com/p/9675f603ff2c?from=groupmessage
ruanyifeng.com/blog/2014/06/git_remote.html

  相关解决方案