背景
相信用过github,然后想要给源码提交PR就必须要首先fork仓库到自己本地
然后再提交代码。但是有个问题是
- 在你fork代码后,源仓库如果继续更新了是不会同步到你本地的
- 即使你继续pull Request也是拉取不到远程仓库的改变
所以导致的问题就是你本地的代码和远程代码版本不一致可能引起冲突,那么如何拉取到远程代码改变的代码呢?
拉取远程仓库代码
最简单方法
最简单的方法也是最无脑的方法不推荐大家使用,就是把自己这个仓库删掉,再重新fork即可。
拉取上游更新代码
-
进入到本地fork的仓库代码
-
执行命令
git remote -v查看本地仓库路径 -
执行命令
git remote add upstream https://github.com/apache/rocketmq命令将git remote add upstream https://github.com/apache/rocketmq源代码地址作为我们的upstream(上游仓库) -
再次执行命令
git remote -v检查是否关联成功可以看到是有
upstream地址了 -
执行命令
git status查看本地是否有修改未提交的代码可以看到我这里是有很多代码没有提交的,那我们先将这些代码提交或者回滚。然后再执行 命令
git status可以看到没有未提交的修改
我这里有点蠢了,就是直接在master上修改,理应自己开个feature分支去修改开发,然后让master永远落后于开源版本不冲突,在更新的时候只更新master,然后再把master merge到自己的分支
-
执行命令
git fetch upstream抓取 rocketmq 原仓库的更新 -
执行命令
git merge upstream/master合并远程的master分支
我们这里是因为改动源码太多了,所以会有冲突,如果你没有改动源码单纯的拉取master的修改是不会有冲突的
这里要是觉得命令不方便也可以直接在idea中使用git插件merge
我这里解决下冲突
- 执行命令
git push把本地仓库向自己的github仓库
然后看看自己的github仓库发现已经更新了