百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

如何在GitHub上更新或同步派生的仓库

wptr33 2025-05-26 19:22 9 浏览

技术背景

在开源项目中,派生(Fork)仓库是常见的操作。当从原始仓库派生一个副本到自己的账户下后,原始仓库可能会持续更新。为了使自己派生的仓库与原始仓库保持同步,就需要进行更新或同步操作。

实现步骤

命令行方式

  1. 添加原始仓库为远程仓库:在本地克隆的派生仓库中,添加原始GitHub仓库作为“远程”仓库。
git remote add upstream https://github.com/whoever/whatever.git
  1. 获取上游仓库的所有分支:从上游仓库获取所有分支及其提交。
git fetch upstream
  1. 切换到主分支:确保当前在主分支上。
git checkout main
  1. 重写主分支:将自己的提交重放在上游主分支之上。
git rebase upstream/main

如果不想重写主分支的历史,可以使用git merge upstream/main

  1. 强制推送(可选):如果进行了变基操作,首次推送到自己的派生仓库时可能需要强制推送。
git push -f origin main

GitHub网页界面方式

  1. 打开GitHub上的派生仓库。
  2. 点击“Pull Requests”。
  3. 点击“New Pull Request”。默认情况下,GitHub会比较原始仓库和派生仓库,如果没有更改则没有可比较的内容。
  4. 如果看到“switching the base”链接,点击它;否则,手动将“base fork”下拉菜单设置为自己的派生仓库,“head fork”设置为上游仓库。此时应该能看到所有最新更改。
  5. 点击“Create pull request”,并为拉取请求指定一个可预测的名称(例如Update from original)。
  6. 滚动到“Merge pull request”,但先不要点击。

GitHub CLI方式

使用gh repo sync子命令并提供派生仓库名称作为参数来更新远程派生仓库。

gh repo sync owner/cli-fork

如果上游仓库的更改导致冲突,GitHub CLI无法同步。可以设置-force标志来覆盖目标分支。

核心代码

命令行完整示例

# 添加远程仓库
git remote add upstream https://github.com/whoever/whatever.git
# 获取上游仓库分支
git fetch upstream
# 切换到主分支
git checkout main
# 重写主分支
git rebase upstream/main
# 强制推送(可选)
git push -f origin main

GitHub CLI示例

gh repo sync owner/cli-fork

最佳实践

  • 定期同步:定期同步派生仓库,以保持与上游仓库的最新状态。
  • 使用变基:如果希望拉取请求尽可能干净,建议使用git rebase而不是git merge
  • 处理冲突:在同步过程中,如果出现冲突,应仔细解决冲突并提交合并。

常见问题

  • 提交历史混乱:使用GitHub网页界面同步可能会导致提交历史混乱。建议使用命令行方式。
  • 强制推送问题:强制推送(git push -f)会覆盖远程仓库的历史,应谨慎使用。
  • 冲突解决:当上游仓库的更改与本地更改冲突时,需要手动解决冲突。可以使用git status查看冲突文件,然后编辑文件并使用git addgit commit提交解决方案。

相关推荐

文科生自学Python-生成简单的WORD文档

--天行健君子以自强不息,地势坤君子以厚德载物,学习编程成就更好的自己--Python语言简洁生动,特别适合文科生学习入门IT世界,用几十行代码就能够做一个完整的爬虫脚本,开发效率杠杠的!短时间内即可...

使用Python 爬取京东、淘宝等商品详情页的数据,避开反爬虫机制

以下是爬取京东商品详情的Python3代码,以excel存放链接的方式批量爬取。excel如下...

CV学习笔记(二十四):数据集标注与制作

最近在做一些数据标注的工作,虽然标注数据比较枯燥,但这也是每个做算法的工程师升级打怪的必由之路。使用一些合适的工具往往可以事半功倍,效率UP。一:数据标注流程二:数据处理的一些小代码1:重命名当得到这...

新手常见的python报错及解决方案(如何理解python报错信息)

此篇文章整理新手编写代码常见的一些错误,有些错误是粗心的错误,但对于新手而已,会折腾很长时间才搞定,所以在此总结下我遇到的一些问题。希望帮助到刚入门的朋友们。后续会不断补充。...

殊途同归python第5节:一键管理所有文档

Python自带的os模块,文件和文件夹的小管家,直接上代码importosa=os.getcwd()#获取当前路径,以字符串形式返回当前的绝对路径。os.chdir("动画片收...

1.文件夹的处理 OS(文件夹的操作方法)

os.getcwd()#当前目录os.listdir()#列出目录下的文件os.path.join()#拼接路径os.path.split()#拆分路径os.path.exists...

Linux下分析bin文件的10种方法(linux binary文件)

这世界有10种人,一种人懂二进制,另一种人不懂二进制。——鲁迅大家好,我是良许。二进制文件是我们几乎每天都需要打交道的文件类型,但很少人知道他们的工作原理。这里所讲的二进制文件,是指一些可执行文件,...

文科生自学Python-pandas交叉透视表降维变换

--心有猛虎,细嗅蔷薇,学习编程成就更好的自己--...

史上最全!近万字梳理Python 开发必备的 os 模块(建议收藏)

点赞、收藏、加关注,下次找我不迷路...

工作中必备的12个Git命令(常用git命令清单)

...

Undoing a git rebase(undoing a git rebase)

技术背景在使用Git进行版本控制时,gitrebase是一个强大的命令,它可以将一个分支的修改合并到另一个分支,使提交历史更加线性。然而,在某些情况下,我们可能需要撤销...

【干货】常用的Git命令有哪些?(git 常用命令行入门)

Git是一个开源的分布式版本控制系统,它被广泛用于软件开发中。在使用Git进行版本控制时,有许多常用的命令,本文将对这些命令进行详细的介绍。...

项目中使用 husky 格式化代码和校验 commit 信息

大家好,我是前端西瓜哥。今天我们学习使用husky工具,在commit的时候做一些风格的校验工作,包括commit信息格式化和文件格式化。githook和husky...

Git可视化极简易教程 — Git GUI使用方法

前言...

实际工作中 Git Commit 代码提交规范是什么样的?

...