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 ,如果覆盖小部分代码还可以,但如果覆盖了大量的代码真的会欲哭无泪,分享这个抢救小技巧,希望大家都能在紧要关头派上用场哦!

相关推荐
切糕师学AI1 分钟前
Ubuntu 下 Git 完全使用指南
linux·git·ubuntu
We་ct3 分钟前
深度剖析浏览器跨域问题
开发语言·前端·浏览器·跨域·cors·同源·浏览器跨域
weixin_4277716128 分钟前
前端调试隐藏元素
前端
永远不会的CC1 小时前
浙江华昱欣实习(4月23日~ 4月19日)
后端·学习
爱上好庆祝1 小时前
学习js的第五天
前端·css·学习·html·css3·js
C澒2 小时前
IntelliPro 产研协作平台:基于 AI Agent 的低代码智能化配置方案设计与实现
前端·低代码·ai编程
一袋米扛几楼982 小时前
【Git】规范化协作:详解 GitHub 工作流中的 Issue、Branch 与 Pull Request 最佳实践
前端·git·github·issue
直奔標竿2 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
嘟嘟MD2 小时前
程序员副业 | 2026年4月复盘
后端·创业
网络点点滴2 小时前
前端与后端的区别与联系
前端