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
相关推荐
驯狼小羊羔11 分钟前
学习随笔-require和import
前端·学习
excel18 分钟前
🚀 从 GPT-5 流式输出看现代前端的流式请求机制(Koa 实现版)
前端
凸头22 分钟前
Spring Boot接收前端参数的注解总结
前端·spring boot·后端
爱吃甜品的糯米团子41 分钟前
JavaScript 正则表达式:选择、分组与引用深度解析
前端·javascript·正则表达式
excel1 小时前
Vue SSR 编译器源码深析:ssrTransformShow 的实现原理与设计哲学
前端
excel1 小时前
深入解析 Vue 3 SSR 编译管线:ssrCodegenTransform 源码全解
前端
excel1 小时前
深入解析 Vue SSR 编译器的核心函数:compile
前端
IT_陈寒1 小时前
Vue 3性能优化实战:7个关键技巧让我的应用加载速度提升50%
前端·人工智能·后端
excel1 小时前
Vue SSR 错误系统源码解析:createSSRCompilerError 与 SSRErrorCodes 的设计原理
前端
excel1 小时前
Vue SSR 源码解析:ssrTransformModel 深度剖析
前端