What if you could undo your biggest Git mistakes in seconds, even after thinking your work was gone?
Why Recovering lost commits with reflog in Git? - Purpose & Use Cases
Start learning this pattern below
Jump into concepts and practice - no test required
Imagine you accidentally deleted some important changes in your project by resetting or switching branches without saving. You realize the commits are gone and panic because you think your work is lost forever.
Manually searching through files or backups to find lost changes is slow and confusing. You might waste hours trying to remember what you did or even rewrite the lost work, which is frustrating and error-prone.
Git's reflog keeps a hidden record of all your branch movements and commits, even those that seem lost. With reflog, you can quickly find and restore lost commits, saving your work and peace of mind.
git reset --hard HEAD~2 # Oops, lost commits!
git reflog
# find lost commit hash
git checkout <commit-hash>You can confidently experiment and fix mistakes by easily recovering lost commits without fear of losing your work.
A developer accidentally resets the branch to an earlier commit, losing recent work. Using reflog, they find the lost commit hash and restore it, avoiding hours of rework.
Lost commits can happen to anyone during normal work.
Manual recovery is slow and unreliable.
Reflog tracks all changes, enabling quick recovery of lost commits.
Practice
git reflog in Git?Solution
Step 1: Understand what reflog tracks
Git reflog records changes to HEAD and branch tips, showing recent commit movements.Step 2: Identify reflog's main use
It helps find lost commits by listing recent HEAD positions, not deleting or merging.Final Answer:
To show a log of where HEAD and branch references have been recently -> Option AQuick Check:
Reflog = recent HEAD changes [OK]
- Confusing reflog with git log
- Thinking reflog deletes commits
- Assuming reflog pushes commits
abc1234 by creating a new branch named recovered?Solution
Step 1: Understand how to create a branch from a commit hash
The commandgit checkout -b <branch> <commit>creates and switches to a new branch at that commit.Step 2: Check each option's correctness
git checkout -b recovered abc1234 uses correct syntax. git branch recovered && git checkout abc1234 creates branch but checks out commit separately (detached HEAD). git reflog checkout abc1234 recovered is invalid syntax. git reset --hard recovered abc1234 misuses reset.Final Answer:
git checkout -b recovered abc1234 -> Option DQuick Check:
Create branch from commit: checkout -b [OK]
- Using git reflog checkout (invalid command)
- Creating branch and checkout separately causing detached HEAD
- Misusing git reset syntax
abc1234 HEAD@{0}: commit: Fix typo
def5678 HEAD@{1}: commit: Add feature
789abcd HEAD@{2}: commit: Initial commitWhat command will restore the commit with message 'Add feature'?
Solution
Step 1: Identify the commit hash for 'Add feature'
From reflog, 'Add feature' commit hash is def5678 at HEAD@{1}.Step 2: Use git checkout with the correct hash
Checking out def5678 restores that commit state.Final Answer:
git checkout def5678 -> Option CQuick Check:
Checkout commit by hash = def5678 [OK]
- Choosing wrong commit hash
- Using HEAD@{2} which is 'Initial commit'
- Confusing latest commit with target commit
git reflog and found a lost commit hash abc1234. You tried git checkout abc1234 but got a detached HEAD warning. How do you fix this to recover the commit safely?Solution
Step 1: Understand detached HEAD state
Checking out a commit hash puts you in detached HEAD, which is risky for new work.Step 2: Create a branch to save the commit safely
Usegit checkout -b recovered abc1234to create a branch and avoid losing commits.Final Answer:
Create a new branch at that commit using git checkout -b recovered abc1234 -> Option AQuick Check:
Fix detached HEAD by creating branch [OK]
- Ignoring detached HEAD and continuing work
- Deleting reflog entries mistakenly
- Trying to push without branch
git reflog and see:abc1234 HEAD@{0}: reset: moving to abc1234
def5678 HEAD@{1}: commit: Add new feature
789abcd HEAD@{2}: commit: Fix bugHow do you restore your branch to include the lost 'Add new feature' commit?
Solution
Step 1: Identify lost commit hash from reflog
The lost commit 'Add new feature' is at def5678 (HEAD@{1}).Step 2: Use git reset to move branch pointer back
Runninggit reset --hard def5678restores branch to that commit, recovering lost work.Final Answer:
Run git reset --hard def5678 to move branch back to lost commit -> Option BQuick Check:
Reset branch to lost commit hash [OK]
- Checking out reset commit instead of resetting branch
- Deleting reflog entries unnecessarily
- Trying to merge without branch pointer
