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

相关推荐
陈随易17 分钟前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart1 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒3 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰3 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林8184 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
用户8356290780514 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
小满zs4 小时前
Go语言第二章(小无相功)
后端·go
用户8356290780514 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
karry_k4 小时前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
妙码生花4 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go