【经验】Git|如何删除错误的commit?(存在大文件无法push的commit、不需要的commit等情况、清除所有commit的情况)
2024/04/24说明:这篇暂时修改为粉丝可见,因为正在冲粉丝量,等到我弄完了粉丝量的要求,我就改回来!不方便看到全文的小伙伴不好意思!!
情况一:尚未推送或无法推送
如果你在本地多次提交了commit,但是其中有一个commit交错了、或者无法推送,
就像下面这张图这样:
你可以安装以下步骤操作。
-
通过
git log
想清楚自己需要切换到哪一个commit状态,查看commit id:# 查看git记录(能看到每次操作的id): git log
-
将仓库的状态恢复到能够正常提交的状态/需要删除的状态的上一个commit状态(
--soft
参数会保证恢复后你的文件夹内容保持不变):git reset --soft <无法上传的那次的上一个的id>
注:id输入6位以上就差不多可以了,多输入几位也行,不用全选
注:git reset 有三种模式:–soft、–hard和不加参数。- –soft是保留工作区的内容和add提交,只是切换指针
- –hard是什么都不保留
- 不加参数是保留工作区的内容但是不保留add提交
在其他情况下,你也可以选择使用其他的参数。
-
检查当前Git的状态,尝试push:
# 可以看到完整的修改记录: git status # 重新提交commit git commit -m "xxxxxx" # 尝试push git push
如果你无法理解以上文字描述以及命令行操作的话,也可以看视频描述,更具体一些,当我还是小白的时候这个视频帮助我圆满解决了这个问题:《从零开始的 Git 生活》Lesson 8 Git 中的后悔药.bilibili.全栈港。
情况二:已经推送
注:最好别用
git revert
撤销提交,有点难用。
如果你不小心已经把错误的 commit 推上去了,也不要紧。
与第一种情况一致,首先,本地执行情况一中提到的三个步骤,回到需要的commit状态。
最后推送时使用强制推送:
git push -f
情况三:想要清除所有的commit记录,只保留一个
情况描述:删库跑路 or 抹杀开发过程 or 保护隐私必备。
首先在 github 网页上或者使用 git log
查看第一个 commit 的 id,然后运行:
git reset --soft <第一个 commit 的 id>
git commit --amend
这两行指令的含义是:
- 将当前分支的状态切换到第一个提交中,并保留本地的修改以及暂存区的设置;
- 将现在的暂存区的内容直接 amend 到前一个提交(在这里指的就是第一个 commit)。
运行这两行指令之后,将会弹出一个新的编辑框,要求填写 commit message。默认的 commit message 就是你的第一个提交的 commit 信息,如果你需要修改,就修改一下。
这一部分的操作很简单也很直观,不过会有人使用 rebase 做这个操作,为了描述为什么不使用 rebase,我添加了一些详细分析。为控制篇幅,我将详细的所有三种方案以及不使用 rebase 的原因写在了另一篇博文里,欢迎阅读:【经验】Git|如何将仓库中所有的 commit 合成一个?又名,如何清除所有 git 提交记录?
本账号所有文章均为原创,欢迎转载,请注明文章出处:
https://blog.csdn.net/qq_46106285/article/details/124744328。百度和各类采集站皆不可信,搜索请谨慎鉴别。技术类文章一般都有时效性,本人习惯不定期对自己的博文进行修正和更新,因此请访问出处以查看本文的最新版本。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix