Github代码fork之后,如何与原仓库进行同步?

简介: Github代码fork之后,如何与原仓库进行同步?

前言

我们在使用GitHub时,看到好的项目或想给某个项目做贡献,此时通常会将代码仓库fork到自己的账号下。如果在此期间,如果源仓库的代码发生了变动,就需要与源仓库代码进行同步。本篇文章就带大家实操一下,如何实现这一操作。

配置项目的上游仓库

首先需要大家将fork的仓库代码clone到本地,后面的所有操作都是基于本地代码库来进行操作的。比如,可以通过git clone先将fork的代码下载到本地:

git clone git@github.com:secbr/nacos.git

后续的一步步操作,都是基于本地仓库来进行操作。

进入到本地仓库目录

通过cd操作,进入到clone下来的本地仓库根目录:

cd /Users/apple/develop/nacos-request/nacos

后续的操作无特殊说明,都是在这个本地仓库的目录下进行操作。

查看远程仓库路径

执行命令 git remote -v 查看远程仓库的路径:

appledeMacBook-Pro-2:nacos apple$ git remote -v
origin  https://github.com/secbr/nacos.git (fetch)
origin  https://github.com/secbr/nacos.git (push)

如果只显示2行内容,说明该项目还未设置upstream(中文叫:上游代码库),一般情况下,设置好一次upstream后就无需重复设置。通过显示远程仓库的路径和clone时的路径对照,会发现,此时远程仓库的路径还是fork项目的路径。

添加upstream路径

执行命令 git remote add upstream https://xxx.git,把fork的源仓库设置为 upstream 。这里项目是从alibaba的nacos仓库fork过来的,因此对应的upstream就是alibaba的源仓库地址。

执行上述命令,在此执行git remote -v 检查是否成功。

appledeMacBook-Pro-2:nacos apple$ git remote add upstream https://github.com/alibaba/nacos.git
appledeMacBook-Pro-2:nacos apple$ git remote -v
origin  https://github.com/secbr/nacos.git (fetch)
origin  https://github.com/secbr/nacos.git (push)
upstream        https://github.com/alibaba/nacos.git (fetch)
upstream        https://github.com/alibaba/nacos.git (push)

通过上面的输出可以看出,多了两项upstream的地址,说明添加upstream成功。

检查本地代码状态

由于我们的实例是直接从仓库clone下来的,本地还没有修改代码。如果你的本地项目已经修改了一些代码,不确定是否提交了代码,就需要执行git status来检查一下。

appledeMacBook-Pro-2:nacos apple$ git status
On branch develop
Your branch is up to date with 'origin/develop'.
nothing to commit, working tree clean

上面显示,本地没有需要提交的(commit)的代码。如果本地有修改,需要先从本地仓库推送到GitHub仓库。然后,再执行一次 git status 检查。

对应推送到GitHub仓库的基本操作步骤如下:

git add -A 或者 git add filename
git commit -m "your note"
git push origin master
git status

完成上面的基本操作之后,确认代码都已经提交,便可以开始执行源仓库与本地仓库的merge操作了。

抓取源仓库的更新

经过上面步骤的准备之后,我们可以进行源仓库的代码更新了。执行命令 git fetch upstream 抓取原仓库的更新:

appledeMacBook-Pro-2:nacos apple$ git fetch upstream
remote: Enumerating objects: 2646, done.
remote: Counting objects: 100% (2593/2593), done.
remote: Compressing objects: 100% (1157/1157), done.
remote: Total 2646 (delta 731), reused 2404 (delta 682), pack-reused 53
Receiving objects: 100% (2646/2646), 1.67 MiB | 1.47 MiB/s, done.
Resolving deltas: 100% (734/734), completed with 37 local objects.
From https://github.com/alibaba/nacos
 * [new branch]          0.2.1                               -> upstream/0.2.1
 * [new branch]          0.2.2                               -> upstream/0.2.2
 * [new branch]          0.3.0                               -> upstream/0.3.0
//...省略一部分

执行上述命令之后,上游仓库的更新(commit)会本存储为本地的分支,通常名称为:upstream/BRANCHNAME。比如上面的upstream/0.3.0。

切换分支

完成了上游仓库分支的拉取之后,先来核查一下本地仓库当前处于哪个分支,也就是需要更新合并的分支。比如,这里我需要将develop分支的内容更新到与上游仓库代码一致。则先切换到develop分支:

appledeMacBook-Pro-2:nacos apple$ git checkout develop
Already on 'develop'
Your branch is up to date with 'origin/develop'.

上面提示已经是develop分支了。

执行合并

执行命令 git merge upstream/develop 合并远程的develop分支。比如你合并的可能是master,可根据需要将develop的名称替换成对应的master。

appledeMacBook-Pro-2:nacos apple$ git merge upstream/develop
Removing test/src/test/java/com/alibaba/nacos/test/naming/DeregisterInstance_ITCase.java
// ...省略一部分
Removing naming/src/test/java/com/alibaba/nacos/naming/core/PushServiceTest.java
Auto-merging client/src/main/java/com/alibaba/nacos/client/naming/remote/http/NamingHttpClientProxy.java
CONFLICT (content): Merge conflict in client/src/main/java/com/alibaba/nacos/client/naming/remote/http/NamingHttpClientProxy.java
Removing client/src/main/java/com/alibaba/nacos/client/naming/core/HostReactor.java
Removing .editorconfig
Automatic merge failed; fix conflicts and then commit the result.

执行完上述命令之后,会发现上游代码指定分支的修改内容已经反映到本地代码了。

上传代码到fork分支

执行完上一步的合并操作之后,往后还有一些后续处理,比如代码冲突。如果本地修改了内容,上游仓库也修改了对应的代码,则可能会出现冲突。这时就需要对比代码进行修改。本人更习惯使用IDEA中可视化的插件进行代码冲突解决,你也可以选择你喜欢的方式进行解决。

解决完冲突之后,就可以执行正常的代码add、commit和push操作了。这里的一系列操作都是针对自己fork的仓库的,对应操作实例如下:

appledeMacBook-Pro-2:nacos apple$ git add .
appledeMacBook-Pro-2:nacos apple$ git commit -m 'merge from nacos'
[develop 8601c1791] merge from nacos 
appledeMacBook-Pro-2:nacos apple$ git push
Enumerating objects: 4, done.
Counting objects: 100% (4/4), done.
Delta compression using up to 12 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (2/2), 281 bytes | 281.00 KiB/s, done.
Total 2 (delta 1), reused 0 (delta 0), pack-reused 0
remote: Resolving deltas: 100% (1/1), completed with 1 local object.
To https://github.com/secbr/nacos.git
   76a4dcbb1..8601c1791  develop -> develop

上述操作,通过add、commit、push一系列操作,将源仓库中的修改内容,提交到自己fork的分支当中了。此时再查看自己fork的GitHub仓库,发现代码已经更新。

小结

本篇文章介绍了当我们fork一个仓库代码之后,如何将上游仓库最新的代码与自己仓库进行同步更新。如果你喜欢fork一些优秀的代码,需要在GitHub上为开源项目做贡献,那么这个基本的操作必须得了解一下。

目录
相关文章
|
23天前
|
人工智能 自然语言处理 安全
Milvus x n8n :自动化拆解Github文档,零代码构建领域知识智能问答
本文介绍了在构建特定技术领域问答机器人时面临的四大挑战:知识滞后性、信息幻觉、领域术语理解不足和知识库维护成本高。通过结合Milvus向量数据库和n8n低代码平台,提出了一种高效的解决方案。该方案利用Milvus的高性能向量检索和n8n的工作流编排能力,构建了一个可自动更新、精准回答技术问题的智能问答系统,并介绍了部署过程中的可观测性和安全性实现方法。
|
1月前
|
存储 人工智能 自然语言处理
让你拥有一个AI大脑,这个32.1k Github项目是你不错的选择,支持PDF、Markdown、代码、视频成为你的知识内容
Quivr 是开源全栈 RAG 平台,助你打造“第二大脑”,支持多文档类型与多种 LLM,实现智能搜索与聊天。具备语义检索、本地部署、隐私保护等功能,适用于个人知识管理与企业知识库,界面简洁易用,是高效智能问答的理想选择。
|
4月前
|
JSON JavaScript API
MCP 实战:用配置与真实代码玩转 GitHub 集成
MCP 实战:用配置与真实代码玩转 GitHub 集成
1142 4
|
3月前
|
Linux 网络安全 开发工具
在Linux下配置gitee与Github的远程仓库
注意,git push后,是输入你的账号与密码。这个步骤可以通过特殊设置省去,但是一开始还是不要太省。
150 0
|
5月前
|
文字识别 网络协议 开发工具
GitHub封锁?推荐5个国产的Git仓库替代平台
近日,GitHub对中国区IP的部分限制引发了广泛关注。未登录用户被拒,已登录用户功能受限,南北网络环境差异更显“内卷”。为应对这一挑战,本文推荐了多个国产Git平台:Gitee(码云)、GitCode(CSDN旗下)、CODING(腾讯系)、CodeUP(阿里云支持)及微信代码管理工具。这些平台功能全面、稳定性强,是开发者迁移项目的理想选择。通过同步代码、配置CI/CD流水线等简单步骤,可确保项目平稳过渡。此次事件提醒我们,掌握核心技能与支持国产平台同样重要!
2362 11
|
6月前
|
人工智能 网络安全 开发工具
vscode代码推送到github库菜鸡专用教程
vscode代码推送到github库菜鸡专用教程
|
6月前
|
开发工具 git
vscode推送项目到github仓库故障解决1
本文介绍了如何优雅解决本地仓库与远程仓库历史记录不一致的问题,并提供避免未来问题的最佳实践。核心在于理解问题根源(如历史记录差异和常见原因),采用推荐的解决方案(先本地初始化再关联远程仓库),并遵循一致的工作流程、团队协作规范及熟悉 Git 命令。通过强制推送或合并无关历史记录等方式处理现有冲突,同时养成良好习惯以预防类似问题。
|
5月前
|
人工智能 数据可视化 前端开发
自学软硬件工程师776天精简版github项目同步推送步骤
注意 这篇文章不是水内容的,虽然我之前也写过 github推送同步的内容。
|
1月前
|
JSON Kubernetes 安全
找到啦,我们已上车,Github 27000+ star,研发团队必备开源工具项目,真丝滑!!!
Trivy 是一款高效灵活的开源安全扫描工具,支持容器镜像、文件系统、Kubernetes 等多目标扫描,具备快速、易用、集成性强等特点,适用于 DevSecOps 全流程安全检测。
|
16天前
|
人工智能 编解码 JSON
不看后悔!GitHub 开源 MultiTalk .8k star 强大的人语音+图像绑定项目
MultiTalk 是 GitHub 上的开源项目,具备音频驱动、多人对话视频生成功能。支持多路音频与图像绑定,实现高同步唇动与角色互动,适用于教学、虚拟人及短视频创作,已获 8k 星标。

热门文章

最新文章