git push -f 的后悔药
说真的,有些指令先存起来放,必要时是能救命的 ,大家可以先把这篇存起来留个印象,真的遇到时可以当作锦囊掏出来用。废话不多说,开始教学!
使用场景
不管什么原因,总之你用了 git push -f
覆盖了远程的分支,你想要撤销刚才的操作,将分支恢复刚才误操作前的状态。
处理步骤
1. git reflog show remotes/ur_upstream/ur_branch
请把 ur_upstream
改成你自己设定的 remote origin
名称,然后把 ur_branch
换成你的 branch
名字,执行完毕后你会看到
2. git reset --hard ur_commit_hash
在前一个步骤你看到一堆 commit hash
,这时候选择一个你要的 commit hash
,把指令中的 ur_commit_hash
替换你要的 commit hash
例如:
reset -- hard 9983b19d
3. git push ur_upstream ur_branch -f
在前一个步骤 reset
完本地的代码后,在本机检查一下是不是你要的版本,如果一切没问题,再直接用回退回来的版本推到远端就大功告成啦!
后记
如果你有用 rebase
整理 commit
的习惯,工作又时常多线开发,需要多个 branch
切换,有时候难免不小心 rebase
整理完,使用 push -f
推错 branch
,如果覆盖小部分代码还可以,但如果覆盖了大量的代码真的会欲哭无泪,分享这个抢救小技巧,希望大家都能在紧要关头派上用场哦!
转载自:https://juejin.cn/post/7338011132383576104