Git 执行 「fork 出来的仓库」和「最新版本的原仓库」内容同步更新


当我们在 GitHub 上 fork 出一个仓库后,如果原仓库更新了,此时怎样才能保证我们 fork 出来的仓库和原仓库内容一致呢?我们一般关注的是仓库的 master(主干分支)的内容,通过以下步骤来保证他最新就可以了。

 

前期准备:

可以使用源码管理可视化工具(客户端)来管理源码,例如「SourceTree」「GitHub Desktop」「Cornerstone」

 

这里我们使用「SourceTree」克隆「fork 出来的仓库」,以 AFNetworking 仓库为例进行介绍

 

 

步骤:

1、添加一个远程仓库,此时只是空壳,还没有同步内容,引用 fork 的原仓库地址

git remote add originUpstream https://github.com/AFNetworking/AFNetworking.git

2、commit(提交)本地的变更;如果本地没有修改内容,此步骤可忽略

git commit

3、更新远程仓库,从引用 fork 的原仓库地址同步内容,此时原仓库的 master(主干分支)已经可以在本地访问了

git remote update originUpstream

4、checkout(检出)用于操作的本地分支 ,比如 master;如果此时分支为已检出状态,此步骤可忽略

git checkout master

5、直接从远程仓库的分支 pull(拉取) 数据

git pull originUpstream master

PS:或者本地已检出分支基于远程仓库的分支进行 rebase(变基)操作

git rebase originUpstream/master

6、把本地已检出分支的已提交数据 push(推送) 到自己 fork 的仓库中

git push origin master

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM