如果要删除最近的几个提交,可以使用 git reset 命令

  • 但是删除最近的提交最好的方法是使用revert, 而不是本篇文章使用的reset

保留修改

git reset --soft HEAD~N
删除提交历史,但保留工作区(已修改的文件)和暂存区(git add 的内容)的修改。

# 删除最近1个提交(保留修改)
git reset --soft HEAD~1

# 删除最近3个提交(保留修改)
git reset --soft HEAD~3

适用场景:提交信息写错了,想重新提交;或者多个小提交想合并后重新提交。

清空暂存区

git reset HEAD~N

删除提交历史,保留工作区修改,但清空暂存区(需要重新 git add)

# 删除最近1个提交(清空暂存区)
git reset HEAD~1  # 等同于 git reset --mixed HEAD~1

适用场景:想重新整理暂存区的文件,再重新提交。

彻底丢弃修改(危险)

git reset --hard HEAD~1

删除提交历史,同时丢弃工作区和暂存区的所有修改(无法恢复)。

# 删除最近1个提交(彻底丢弃修改)
git reset --hard HEAD~1
适用场景:确定这些修改完全不需要,想回到之前的干净状态。

删除中间的提交(本地)

如果要删除历史中的某个特定提交(非最近的),需要使用 git rebase -i(交互式变基)

操作步骤

  1. 查看提交历史,找到要删除的提交的前一个提交 ID:
git log --oneline
# 示例输出:
# a1b2c3d (HEAD) 最近的提交
# d4e5f6g 要删除的提交 ← 目标
# g7h8i9j 更早的提交
  1. 执行交互式变基,范围是从要删除的提交的前一个开始:
# 格式:git rebase -i <要删除的提交的前一个提交ID>
git rebase -i g7h8i9j
  1. 在编辑器中删除目标提交:编辑器会显示提交列表,将目标提交行的 pick 改为 drop(或直接删除该行):
# 原内容:
pick d4e5f6g 要删除的提交
pick a1b2c3d 最近的提交

# 修改为(二选一):
drop d4e5f6g 要删除的提交  # 方法1:改为 drop
pick a1b2c3d 最近的提交

# 或直接删除目标提交行(方法2):
pick a1b2c3d 最近的提交
  1. 保存退出编辑器,Git 会自动完成变基,目标提交被删除

删除远程仓库的提交

如果提交已经推送到远程仓库(如 GitHub/GitLab),需要强制推送来覆盖远程历史。

  • 先删除本地提交, 使用上述 git reset 或 git rebase -i 方法删除本地提交。
  • 强制推送到远程
# 方法1:基本强制推送(简单但风险较高)
git push -f origin <分支名>

# 方法2:安全强制推送(推荐,会检查远程是否有新提交)
git push --force-with-lease origin <分支名>
Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐