Git / Git
Git refusing to merge unrelated histories
Fix Git refusing to merge unrelated histories when combining repositories or mismatched branches.
- Category
- Git
- Error signature
fatal: refusing to merge unrelated histories- Quick fix
- Confirm the histories should be combined, then merge with --allow-unrelated-histories and resolve conflicts carefully.
- Updated
What this error means
fatal: refusing to merge unrelated histories means Git cannot complete the requested repository operation with the current directory, remote, branch history, or SSH/HTTPS credentials. Inspect repository state before forcing commands.
Why this happens
Git is stateful: the current branch, remote URL, working directory, and configured identity all affect the same command.
For Git refusing to merge unrelated histories, verify the repository state and remote access before rewriting history or changing credentials.
Common causes
- Local repository was initialized separately from the remote
- Two independent repositories are being combined
- Default branch was recreated
- Remote history was replaced
Quick fixes
- Run
git statusfrom the directory where the error appears. - Check remotes with
git remote -v. - Confirm the histories should be combined, then merge with —allow-unrelated-histories and resolve conflicts carefully.
- Retry using the same SSH or HTTPS remote style your team expects.
Copy-paste commands
Check repository state
git status
Show remotes
git remote -v
List local branches
git branch
Fetch remote refs
git fetch origin
Test GitHub SSH
ssh -T git@github.com
Real-world fixes
- If SSH fails, confirm the public key is added to the account that owns the repository.
- If a remote URL is wrong, update it with
git remote set-url origin <url>instead of adding a duplicate remote. - Confirm the histories should be combined, then merge with —allow-unrelated-histories and resolve conflicts carefully.
Step-by-step troubleshooting
- Copy the exact
fatal: refusing to merge unrelated historiesline and the Git command that produced it. - Run
git statusto confirm you are inside the intended repository. - Run
git remote -vand verify SSH versus HTTPS matches your credential setup. - Run
git fetch originto separate network/auth problems from local branch problems. - Avoid force pushes or history rewrites until you know which branch and remote are affected.
How to prevent it
- Document the expected remote URL format for the project.
- Use SSH config host aliases when working with multiple Git accounts.
- Check branch and remote before running destructive Git commands.
Related errors
- fatal: not a git repository
- fatal: refusing to merge unrelated histories
- CONFLICT content
FAQ
What should I check first?
Start with the exact fatal: refusing to merge unrelated histories line and the command, request, or workflow step that produced it. In Git, the first useful clue is usually near the first failure line, not the final stack trace.
Can I ignore this error?
No. Treat it as a failed Git step. A temporary bypass may help diagnosis, but the underlying cause should be fixed before shipping or publishing changes.
Why does this work locally but fail elsewhere?
Local machines often have cached credentials, old dependencies, different runtime versions, or network settings that CI and production do not share. Reproduce from a clean shell or clean install when possible.
How do I know the fix worked?
Rerun the smallest command, request, or deployment step that produced fatal: refusing to merge unrelated histories. The fix is working when that step completes without the same signature and produces the expected output.