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

相关推荐
PILIPALAPENG几秒前
gh:终端里的GitHub总控台,AI时代的开发者神器
前端·人工智能·后端
用户059540174466 分钟前
Redis持久化踩坑实录:RDB+AOF混合持久化,竟会悄无声息丢数据?我用pytest+Docker复现了30次故障场景
前端·css
浮游本尊8 分钟前
项目全景 + 第一条完整后端链路
java·前端
jeffer_liu8 分钟前
Spring AI 生产级实战:模型选择
java·人工智能·spring boot·后端·spring·语言模型·ai编程
XovH13 分钟前
第 35 篇 k8s之PVC 与 StorageClass:动态存储供应
后端
小新11013 分钟前
vue架的网站修改端口
前端·javascript·vue.js
暗不需求16 分钟前
从零实现一个 Vue Todos 任务清单:深入响应式编程与组合式 API
前端·vue.js·面试
超绝大帅哥16 分钟前
TTFB, FP, FCP, LCP, CLS, INP,TBT, TTI性能指标
前端
用户17335980753719 分钟前
纯前端 PDF 处理避坑指南:5 个线上真实问题的解决方案
前端·javascript
摆烂菜鸡沧99620 分钟前
【自用整理】本地关联GitHub多账号设置
git·github