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

相关推荐
Nan_Shu_61428 分钟前
Web前端面试题(2)
前端
知识分享小能手35 分钟前
React学习教程,从入门到精通,React 组件核心语法知识点详解(类组件体系)(19)
前端·javascript·vue.js·学习·react.js·react·anti-design-vue
用户21411832636021 小时前
Qwen3-Coder 实战!历史人物短视频一键生成,多分镜人物不崩,魔搭直接玩
后端
追逐时光者1 小时前
C#/.NET/.NET Core技术前沿周刊 | 第 54 期(2025年9.8-9.14)
后端·.net
追逐时光者1 小时前
C#/.NET/.NET Core编程技巧练习集,配套详细的文章教程讲解!
后端·.net
蚂蚁RichLab前端团队2 小时前
🚀🚀🚀 RichLab - 花呗前端团队招贤纳士 - 【转岗/内推/社招】
前端·javascript·人工智能
AD钙奶-lalala2 小时前
SpringBoot实现WebSocket服务端
spring boot·后端·websocket
孩子 你要相信光2 小时前
css之一个元素可以同时应用多个动画效果
前端·css
moxiaoran57532 小时前
Flask学习笔记(一)
后端·python·flask
huangql5202 小时前
npm 发布流程——从创建组件到发布到 npm 仓库
前端·npm·node.js