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
相关推荐
共创splendid--与您携手23 分钟前
AI读取前端项目生成skill.md
前端·人工智能·ai
San813_LDD1 小时前
[C语言]《Dev-C++ 报错解决手册(Day0607 精华版)》
java·前端·javascript
xiaofeichaichai7 小时前
Webpack
前端·webpack·node.js
问心无愧05138 小时前
ctf show web入门111
android·前端·笔记
唐某人丶8 小时前
模型越来越强,我们还需要 Agent 工程吗?—— 从价值重估到 Harness 实践
前端·agent·ai编程
智码看视界8 小时前
现代Web开发基础:全栈工程师的起航点
前端·后端·c5全栈
JS菌8 小时前
手写一个 AI Agent 全栈项目:从沙箱执行到子智能体的完整实现
前端·人工智能·后端
excel10 小时前
HLS TS 文件损坏的元凶:Git 提交与拉取
前端
Aphasia31110 小时前
https连接传输流程
前端·面试