Git自学成才——fork仓库保持同步

fork别人的项目到自己的repository,然后clone到本地进行开发。然后别人的项目也在继续开发,本文主要说明如何把fork的项目的新的提交同步到自己的仓库。

核心思想是利用多个远程仓库(remote repository)

先执行完fork,然后到自己的仓库clone代码下来,以master分支为例

$ git branch 
* master

保持工作目录是最新的并且是干净的

$ git status 
On branch master 
Your branch is up to date with 'origin/master'. 

nothing to commit, working tree clean

接下来,看一下远程仓库

$ git remote -v 
origin ssh://git@xxx/YOUR_REPO/my-android.git (fetch) 
origin ssh://git@xxx/YOUR_REPO/my-android.git (push)

此处origin别名对应的远程仓库地指向的是自己的仓库(因为是从自己的仓库clone的)

接下来,我们要添加对于目标仓库(别人的仓库)的指向。

$ git remote add upstream ssh://git@xxx/UPSTREAM_REPO/my-android.git

然后再看一下远程仓库情况

$ git remote -v 
origin ssh://git@xxx/YOUR_REPO/my-android.git (fetch) 
origin ssh://git@xxx/YOUR_REPO/my-android.git (push) 
upstream ssh://git@xxx/UPSTREAM_REPO/my-android.git (fetch) 
upstream ssh://git@xxx/UPSTREAM_REPO/my-android.git (push)

已经关联了远程仓库了,使用sourcetree直观的看一下状态

同步之前.png

从图中看出,我fork之后,对方的仓库又有很多次提交,这时我的仓库里也有几次提交,通过rebase来保持同步。

rebase upstream的master分支

$ git rebase upstream/master

然后就是普通rebase的操作,如果有冲突不知道怎么解决,请参考我的另一篇“Git自学成才——rebase完整版

完成rebase之后,看一下节点是OK的

完成rebase.png

接下来是要执行push,如果直接push到自己的远程仓库,是被拒绝的

$ git push origin master:master
 ! [rejected]        master -> master (non-fast-forward)
error: failed to push some refs to 'ssh://git@xxx/YOUR_REPO/my-android.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

这时有两种方法:一种是删除远程分支,然后直接push;另一种是使用 git push --force 强制推送。

这里我选择第二种强推的方式,第一种方式参见我的另一篇“Git自学成才——rebase完整版

$ git push -f origin master:master
Compressing objects: 100% (186/186), done.
Writing objects: 100% (281/281), 66.82 KiB | 11.14 MiB/s, done.
Total 281 (delta 126), reused 184 (delta 41)
remote: Resolving deltas: 100% (126/126), completed with 54 local objects.
To ssh://git@xxx/YOUR_REPO/my-android.git
 + 8aaa796...d298312 master -> master (forced update)

push成功,看一下sourcetree上面的状态也是OK的。

完成push.png

至此,同步了别人仓库的最新提交,也保有了自己的提交。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 多种多样的工作流使得在项目中实施Git时变得难以选择。这份教程提供了一个出发点,调查企业团队最常见的Git工作流。...
    JSErik阅读 9,939评论 2 8
  • git 指南 git操作 本地操作 git add <file>暂存工作区的修改到暂存区 git commit将暂...
    IrisZL阅读 3,741评论 0 0
  • 查看、添加、提交、删除、找回,重置修改文件 git help # 显示command的help git sho...
    Swiftor阅读 6,416评论 0 2
  • 1. GIT命令 git init在本地新建一个repo,进入一个项目目录,执行git init,会初始化一个re...
    江边一蓑烟阅读 4,266评论 0 0
  • 当我慢慢将你忘却 你也渐渐将我模糊 情已走远 话已随风 不再有牵挂 不再纠缠丝毫 各不相欠 淡淡的回忆里 只有浅浅...
    君酒浓阅读 1,792评论 0 1

友情链接更多精彩内容