当前位置:   article > 正文

你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗_gitlab从fork的项目拉代码

gitlab从fork的项目拉代码

背景

相信用过github,然后想要给源码提交PR就必须要首先fork仓库到自己本地
在这里插入图片描述
在这里插入图片描述

然后再提交代码。但是有个问题是

  1. 在你fork代码后,源仓库如果继续更新了是不会同步到你本地的
  2. 即使你继续pull Request也是拉取不到远程仓库的改变

所以导致的问题就是你本地的代码和远程代码版本不一致可能引起冲突,那么如何拉取到远程代码改变的代码呢?

拉取远程仓库代码

最简单方法

最简单的方法也是最无脑的方法不推荐大家使用,就是把自己这个仓库删掉,再重新fork即可。

拉取上游更新代码

  1. 进入到本地fork的仓库代码
    在这里插入图片描述

  2. 执行命令git remote -v 查看本地仓库路径
    在这里插入图片描述

  3. 执行命令git remote add upstream https://github.com/apache/rocketmq命令将git remote add upstream https://github.com/apache/rocketmq源代码地址作为我们的upstream(上游仓库)

  4. 再次执行命令git remote -v检查是否关联成功
    在这里插入图片描述
    可以看到是有upstream地址了

  5. 执行命令git status查看本地是否有修改未提交的代码
    在这里插入图片描述
    可以看到我这里是有很多代码没有提交的,那我们先将这些代码提交或者回滚。然后再执行
    命令git status
    在这里插入图片描述
    可以看到没有未提交的修改

我这里有点蠢了,就是直接在master上修改,理应自己开个feature分支去修改开发,然后让master永远落后于开源版本不冲突,在更新的时候只更新master,然后再把master merge到自己的分支

  1. 执行命令 git fetch upstream 抓取 rocketmq 原仓库的更新
    在这里插入图片描述

  2. 执行命令 git merge upstream/master 合并远程的master分支

在这里插入图片描述
我们这里是因为改动源码太多了,所以会有冲突,如果你没有改动源码单纯的拉取master的修改是不会有冲突的

这里要是觉得命令不方便也可以直接在idea中使用git插件merge
在这里插入图片描述
我这里解决下冲突

  1. 执行命令 git push 把本地仓库向自己的github仓库
    在这里插入图片描述

然后看看自己的github仓库发现已经更新了
在这里插入图片描述

参考 https://github.com/selfteaching/the-craft-of-selfteaching/issues/67

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/797471
推荐阅读
相关标签
  

闽ICP备14008679号