🚀 快速安装
复制以下命令并运行,立即安装此 Skill:
npx skills add https://github.com/wshobson/agents --skill git-advanced-workflows
💡 提示:需要 Node.js 和 NPM
Git 高级工作流
掌握高级 Git 技术,以维护清晰的历史记录、高效协作并自信地从任何情况中恢复。
何时使用此技能
- 在合并前清理提交历史
- 跨分支应用特定提交
- 查找引入错误的提交
- 同时处理多个功能
- 从 Git 错误或丢失的提交中恢复
- 管理复杂的分支工作流
- 准备清晰的拉取请求以供审查
- 同步已分叉的分支
核心概念
1. 交互式变基
交互式变基是 Git 历史编辑的瑞士军刀。
常用操作:
pick: 保持提交原样reword: 更改提交消息edit: 修改提交内容squash: 与前一个提交合并fixup: 类似于 squash,但丢弃消息drop: 完全移除提交
基本用法:
# 变基最后 5 个提交
git rebase -i HEAD~5
# 变基当前分支上的所有提交
git rebase -i $(git merge-base HEAD main)
# 变基到特定提交
git rebase -i abc123
2. 拣选
将一个分支的特定提交应用到另一个分支,而无需合并整个分支。
# 拣选单个提交
git cherry-pick abc123
# 拣选一系列提交(独占起始)
git cherry-pick abc123..def456
# 拣选但不提交(仅暂存更改)
git cherry-pick -n abc123
# 拣选并编辑提交消息
git cherry-pick -e abc123
3. Git Bisect
通过提交历史进行二分查找,以找到引入错误的提交。
# 开始二分查找
git bisect start
# 标记当前提交为 bad
git bisect bad
# 标记已知的好提交
git bisect good v1.0.0
# Git 会检出中间的提交 - 测试它
# 然后标记为好或坏
git bisect good # 或: git bisect bad
# 继续直到找到错误
# 完成后
git bisect reset
自动化 Bisect:
# 使用脚本自动测试
git bisect start HEAD v1.0.0
git bisect run ./test.sh
# test.sh 对于好的提交应退出 0,对于坏的提交应退出 1-127(125 除外)
4. 工作树
同时处理多个分支,无需暂存或切换。
# 列出已有的工作树
git worktree list
# 为功能分支添加新工作树
git worktree add ../project-feature feature/new-feature
# 添加工作树并创建新分支
git worktree add -b bugfix/urgent ../project-hotfix main
# 移除工作树
git worktree remove ../project-feature
# 清理过时的工作树
git worktree prune
5. Reflog
你的安全网 – 跟踪所有引用的移动,甚至是被删除的提交。
# 查看 reflog
git reflog
# 查看特定分支的 reflog
git reflog show feature/branch
# 恢复已删除的提交
git reflog
# 找到提交哈希
git checkout abc123
git branch recovered-branch
# 恢复已删除的分支
git reflog
git branch deleted-branch abc123
实用工作流
工作流 1:在拉取请求前清理功能分支
# 从功能分支开始
git checkout feature/user-auth
# 交互式变基以清理历史
git rebase -i main
# 示例变基操作:
# - 合并 "fix typo" 提交
# - 修改提交消息使其清晰
# - 按逻辑重新排序提交
# - 删除不必要的提交
# 强制推送清理后的分支(如果没有其他人使用,则安全)
git push --force-with-lease origin feature/user-auth
工作流 2:将热修复应用到多个版本
# 在 main 上创建修复
git checkout main
git commit -m "fix: critical security patch"
# 应用到发布分支
git checkout release/2.0
git cherry-pick abc123
git checkout release/1.9
git cherry-pick abc123
# 如果出现冲突,处理冲突
git cherry-pick --continue
# 或
git cherry-pick --abort
工作流 3:查找引入的错误
# 开始二分查找
git bisect start
git bisect bad HEAD
git bisect good v2.1.0
# Git 检出中间的提交 - 运行测试
npm test
# 如果测试失败
git bisect bad
# 如果测试通过
git bisect good
# Git 将自动检出下一个要测试的提交
# 重复直到找到错误
# 自动化版本
git bisect start HEAD v2.1.0
git bisect run npm test
工作流 4:多分支开发
# 主项目目录
cd ~/projects/myapp
# 为紧急 bug 修复创建工作树
git worktree add ../myapp-hotfix hotfix/critical-bug
# 在单独的目录中处理热修复
cd ../myapp-hotfix
# 进行更改,提交
git commit -m "fix: resolve critical bug"
git push origin hotfix/critical-bug
# 返回主工作而不中断
cd ~/projects/myapp
git fetch origin
git cherry-pick hotfix/critical-bug
# 完成后清理
git worktree remove ../myapp-hotfix
工作流 5:从错误中恢复
# 意外重置到错误的提交
git reset --hard HEAD~5 # 哦不!
# 使用 reflog 查找丢失的提交
git reflog
# 输出显示:
# abc123 HEAD@{0}: reset: moving to HEAD~5
# def456 HEAD@{1}: commit: my important changes
# 恢复丢失的提交
git reset --hard def456
# 或从丢失的提交创建分支
git branch recovery def456
高级技术
变基与合并策略
何时变基:
- 在推送前清理本地提交
- 保持功能分支与主分支同步
- 创建线性历史以便于审查
何时合并:
- 将已完成的功能集成到主分支
- 保留确切的协作历史
- 被其他人使用的公共分支
# 使用主分支更改更新功能分支(变基)
git checkout feature/my-feature
git fetch origin
git rebase origin/main
# 处理冲突
git status
# 修复文件中的冲突
git add .
git rebase --continue
# 或者改为合并
git merge origin/main
自动压缩工作流
在变基期间自动压缩修复提交。
# 进行初始提交
git commit -m "feat: add user authentication"
# 稍后,修复该提交中的某些内容
# 暂存更改
git commit --fixup HEAD # 或指定提交哈希
# 进行更多更改
git commit --fixup abc123
# 使用自动压缩变基
git rebase -i --autosquash main
# Git 会自动标记修复提交
拆分提交
将一个提交拆分为多个逻辑提交。
# 启动交互式变基
git rebase -i HEAD~3
# 用 'edit' 标记要拆分的提交
# Git 将停在该提交处
# 重置提交但保留更改
git reset HEAD^
# 按逻辑块暂存和提交
git add file1.py
git commit -m "feat: add validation"
git add file2.py
git commit -m "feat: add error handling"
# 继续变基
git rebase --continue
部分拣选
仅从提交中拣选特定文件。
# 显示提交中的文件
git show --name-only abc123
# 从提交中检出特定文件
git checkout abc123 -- path/to/file1.py path/to/file2.py
# 暂存并提交
git commit -m "cherry-pick: apply specific changes from abc123"
最佳实践
- 始终使用 –force-with-lease:比 –force 更安全,防止覆盖他人的工作
- 仅变基本地提交:不要变基已经推送和共享的提交
- 描述性的提交消息:未来的你会感谢现在的你
- 原子提交:每个提交应该是一个单一的逻辑更改
- 在强制推送前测试:确保历史重写没有破坏任何东西
- 保持 Reflog 意识:记住 reflog 是你的安全网,有效期为 90 天
- 在进行有风险的操作前创建分支:在复杂的变基前创建备份分支
# 安全的强制推送
git push --force-with-lease origin feature/branch
# 在进行有风险的操作前创建备份
git branch backup-branch
git rebase -i main
# 如果出现问题
git reset --hard backup-branch
常见陷阱
- 变基公共分支:为协作者造成历史冲突
- 未经检查的强制推送:可能覆盖队友的工作
- 在变基中丢失工作:仔细解决冲突,变基后测试
- 忘记清理工作树:孤立的工作树会占用磁盘空间
- 实验前不备份:始终创建安全分支
- 在工作目录脏时进行二分查找:在二分查找前提交或暂存
恢复命令
# 中止进行中的操作
git rebase --abort
git merge --abort
git cherry-pick --abort
git bisect reset
# 将文件恢复到特定提交的版本
git restore --source=abc123 path/to/file
# 撤消最后一次提交但保留更改
git reset --soft HEAD^
# 撤消最后一次提交并丢弃更改
git reset --hard HEAD^
# 恢复已删除的分支(90 天内)
git reflog
git branch recovered-branch abc123
📄 原始文档
完整文档(英文):
https://skills.sh/wshobson/agents/git-advanced-workflows
💡 提示:点击上方链接查看 skills.sh 原始英文文档,方便对照翻译。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

评论(0)