Fork工作流

在 Git 中,你可以设置一个额外的远程仓库(通常称为 upstream),用于跟踪原始项目(如开源项目)的更新。这在 Fork 工作流 中非常常见,例如:

  • 你 Fork 了某个仓库(origin 指向你的 Fork)。
  • 你需要同步原始仓库(upstream 指向原始项目)。

1. 添加 upstream 远程仓库

(1) 查看当前远程仓库

复制代码
git remote -v

默认只有 origin(你的 Fork):

scss 复制代码
origin  git@github.com:your-username/repo.git (fetch)
origin  git@github.com:your-username/repo.git (push)

(2) 添加 upstream(原始仓库)

csharp 复制代码
git remote add upstream https://github.com/original-owner/repo.git
  • upstream 是自定义名称(常用,但你可以换成其他名字)。
  • 如果是 SSH 方式(推荐):
scss 复制代码
git remote add upstream git@github.com:original-owner/repo.git

(3) 验证是否添加成功

复制代码
git remote -v

输出:

perl 复制代码
origin    git@github.com:your-username/repo.git (fetch)
origin    git@github.com:your-username/repo.git (push)
upstream  https://github.com/original-owner/repo.git (fetch)
upstream  https://github.com/original-owner/repo.git (push)

2. 从 upstream 拉取更新

(1) 获取 upstream 的最新代码

sql 复制代码
git fetch upstream

(2) 合并 upstream 的更新到你的本地分支

假设你想同步 upstream/main 到你的 main 分支:

css 复制代码
git checkout main          # 切换到你的本地 main 分支
git merge upstream/main   # 合并 upstream 的 main 分支

如果出现冲突,需要手动解决后提交:

sql 复制代码
git add .
git commit -m "Merge upstream changes"

(3) 推送到你的 origin(Fork 仓库)

css 复制代码
git push origin main

3. 更新 upstream 的 URL(如果需要修改)

如果 upstream 地址有变(如从 HTTPS 切换到 SSH):

kotlin 复制代码
git remote set-url upstream git@github.com:original-owner/repo.git

4. 删除 upstream(如果需要)

arduino 复制代码
git remote remove upstream

5. 典型工作流示例

场景:你 Fork 了一个仓库,现在想同步原始仓库的最新代码。

bash 复制代码
# 1. 添加 upstream(原始仓库)
git remote add upstream https://github.com/original-owner/repo.git

# 2. 获取 upstream 的最新代码
git fetch upstream

# 3. 切换到你的本地 main 分支
git checkout main

# 4. 合并 upstream 的 main 分支
git merge upstream/main

# 5. 推送到你的 origin(Fork 仓库)
git push origin main
相关推荐
wuhen_n8 小时前
网络请求在Vite层的代理与Mock:告别跨域和后端依赖
前端·javascript·vue.js
用户693717500138413 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦13 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户693717500138413 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水14 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫15 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll12316 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
蓝冰凌17 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛17 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js