git-advanced-workflows
掌握高级Git工作流,包括变基(rebase)、拣选(cherry-pick)、二分查找(bisect)、工作树(worktrees)与引用日志(reflog),以保持提交历史的整洁并应对各类异常场景。适用于管理复杂的Git历史记录、协作开发功能分支或排查仓库问题。
Git Advanced Workflows
Master advanced Git techniques to maintain clean history, collaborate effectively, and recover from any situation with confidence.
Do not use this skill when
Instructions
resources/implementation-playbook.md.Use this skill when
Core Concepts
1. Interactive Rebase
Interactive rebase is the Swiss Army knife of Git history editing.
Common Operations:
pick: Keep commit as-isreword: Change commit messageedit: Amend commit contentsquash: Combine with previous commitfixup: Like squash but discard messagedrop: Remove commit entirelyBasic Usage:
# Rebase last 5 commits
git rebase -i HEAD~5Rebase all commits on current branch
git rebase -i $(git merge-base HEAD main)Rebase onto specific commit
git rebase -i abc1232. Cherry-Picking
Apply specific commits from one branch to another without merging entire branches.
# Cherry-pick single commit
git cherry-pick abc123Cherry-pick range of commits (exclusive start)
git cherry-pick abc123..def456Cherry-pick without committing (stage changes only)
git cherry-pick -n abc123Cherry-pick and edit commit message
git cherry-pick -e abc1233. Git Bisect
Binary search through commit history to find the commit that introduced a bug.
# Start bisect
git bisect startMark current commit as bad
git bisect badMark known good commit
git bisect good v1.0.0Git will checkout middle commit - test it
Then mark as good or bad
git bisect good # or: git bisect badContinue until bug found
When done
git bisect resetAutomated Bisect:
# Use script to test automatically
git bisect start HEAD v1.0.0
git bisect run ./test.shtest.sh should exit 0 for good, 1-127 (except 125) for bad
4. Worktrees
Work on multiple branches simultaneously without stashing or switching.
# List existing worktrees
git worktree listAdd new worktree for feature branch
git worktree add ../project-feature feature/new-featureAdd worktree and create new branch
git worktree add -b bugfix/urgent ../project-hotfix mainRemove worktree
git worktree remove ../project-featurePrune stale worktrees
git worktree prune5. Reflog
Your safety net - tracks all ref movements, even deleted commits.
# View reflog
git reflogView reflog for specific branch
git reflog show feature/branchRestore deleted commit
git reflog
Find commit hash
git checkout abc123
git branch recovered-branchRestore deleted branch
git reflog
git branch deleted-branch abc123Practical Workflows
Workflow 1: Clean Up Feature Branch Before PR
# Start with feature branch
git checkout feature/user-authInteractive rebase to clean history
git rebase -i mainExample rebase operations:
- Squash "fix typo" commits
- Reword commit messages for clarity
- Reorder commits logically
- Drop unnecessary commits
Force push cleaned branch (safe if no one else is using it)
git push --force-with-lease origin feature/user-authWorkflow 2: Apply Hotfix to Multiple Releases
# Create fix on main
git checkout main
git commit -m "fix: critical security patch"Apply to release branches
git checkout release/2.0
git cherry-pick abc123git checkout release/1.9
git cherry-pick abc123
Handle conflicts if they arise
git cherry-pick --continue
or
git cherry-pick --abortWorkflow 3: Find Bug Introduction
# Start bisect
git bisect start
git bisect bad HEAD
git bisect good v2.1.0Git checks out middle commit - run tests
npm testIf tests fail
git bisect badIf tests pass
git bisect goodGit will automatically checkout next commit to test
Repeat until bug found
Automated version
git bisect start HEAD v2.1.0
git bisect run npm testWorkflow 4: Multi-Branch Development
# Main project directory
cd ~/projects/myappCreate worktree for urgent bugfix
git worktree add ../myapp-hotfix hotfix/critical-bugWork on hotfix in separate directory
cd ../myapp-hotfix
Make changes, commit
git commit -m "fix: resolve critical bug"
git push origin hotfix/critical-bugReturn to main work without interruption
cd ~/projects/myapp
git fetch origin
git cherry-pick hotfix/critical-bugClean up when done
git worktree remove ../myapp-hotfixWorkflow 5: Recover from Mistakes
# Accidentally reset to wrong commit
git reset --hard HEAD~5 # Oh no!Use reflog to find lost commits
git reflog
Output shows:
abc123 HEAD@{0}: reset: moving to HEAD~5
def456 HEAD@{1}: commit: my important changes
Recover lost commits
git reset --hard def456Or create branch from lost commit
git branch recovery def456Advanced Techniques
Rebase vs Merge Strategy
When to Rebase:
When to Merge:
# Update feature branch with main changes (rebase)
git checkout feature/my-feature
git fetch origin
git rebase origin/mainHandle conflicts
git status
Fix conflicts in files
git add .
git rebase --continueOr merge instead
git merge origin/mainAutosquash Workflow
Automatically squash fixup commits during rebase.
# Make initial commit
git commit -m "feat: add user authentication"Later, fix something in that commit
Stage changes
git commit --fixup HEAD # or specify commit hashMake more changes
git commit --fixup abc123Rebase with autosquash
git rebase -i --autosquash mainGit automatically marks fixup commits
Split Commit
Break one commit into multiple logical commits.
# Start interactive rebase
git rebase -i HEAD~3Mark commit to split with 'edit'
Git will stop at that commit
Reset commit but keep changes
git reset HEAD^Stage and commit in logical chunks
git add file1.py
git commit -m "feat: add validation"git add file2.py
git commit -m "feat: add error handling"
Continue rebase
git rebase --continuePartial Cherry-Pick
Cherry-pick only specific files from a commit.
# Show files in commit
git show --name-only abc123Checkout specific files from commit
git checkout abc123 -- path/to/file1.py path/to/file2.pyStage and commit
git commit -m "cherry-pick: apply specific changes from abc123"Best Practices
# Safe force push
git push --force-with-lease origin feature/branchCreate backup before risky operation
git branch backup-branch
git rebase -i main
If something goes wrong
git reset --hard backup-branchCommon Pitfalls
Recovery Commands
# Abort operations in progress
git rebase --abort
git merge --abort
git cherry-pick --abort
git bisect resetRestore file to version from specific commit
git restore --source=abc123 path/to/fileUndo last commit but keep changes
git reset --soft HEAD^Undo last commit and discard changes
git reset --hard HEAD^Recover deleted branch (within 90 days)
git reflog
git branch recovered-branch abc123