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


  • 背景

  • 拉取远程仓库代码

    • 最简单方法

    • 拉取上游更新代码


背景

相信用过github,然后想要给源码提交PR就必须要首先fork仓库到自己本地你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

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

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

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

拉取远程仓库代码

最简单方法

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

拉取上游更新代码

  1. 进入到本地fork的仓库代码你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

  2. 执行命令git remote -v 查看本地仓库路径你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

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

  4. 再次执行命令git remote -v检查是否关联成功你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗可以看到是有upstream地址了

  5. 执行命令git status查看本地是否有修改未提交的代码你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗可以看到我这里是有很多代码没有提交的,那我们先将这些代码提交或者回滚。然后再执行 命令git status你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗可以看到没有未提交的修改

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

  1. 执行命令 git fetch upstream 抓取 rocketmq 原仓库的更新你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

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

你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗我们这里是因为改动源码太多了,所以会有冲突,如果你没有改动源码单纯的拉取master的修改是不会有冲突的

这里要是觉得命令不方便也可以直接在idea中使用git插件merge你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗我这里解决下冲突

  1. 执行命令 git push 把本地仓库向自己的github仓库你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

然后看看自己的github仓库发现已经更新了你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

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


原文始发于微信公众号(小奏技术):你知道Github fork开源仓库后如何拉取远程仓库更新的代码吗

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/30109.html

(1)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!