git版本提交后撤销

git版本提交后撤销

在 Git 中,撤销提交主要分两种场景:仅撤销最后一次提交撤销历史中某次提交,核心思路是先处理本地提交,再强制推送到远程覆盖。

场景 1:撤销最后一次提交(最常用)

如果只是想撤销最新的一次提交(包括本地 + 远程),推荐用 git reset 命令,这是最安全的方式。

步骤 1:撤销本地最后一次提交(保留代码改动)

如果你想保留修改的代码(只是撤销提交记录),执行:

bash 复制代码
# --soft 保留代码改动,回到 "已修改但未提交" 状态
git reset --soft HEAD~1

如果你想彻底删除最后一次提交的所有代码改动(谨慎使用),执行:

bash 复制代码
git reset --hard HEAD~1
  • HEAD~1 表示 "上一个版本",HEAD~2 就是上上个版本,以此类推。

步骤 2:强制推送到远程仓库(覆盖远程记录)

本地撤销后,需要强制推送才能同步到远程(远程仓库允许强制提交):

bash 复制代码
git push -f origin 分支名 # 如 git push -f origin master

注意:git push -f 是强制推送,会覆盖远程仓库的提交记录,如果多人协作,请确保团队成员知晓,避免覆盖他人的提交

场景 2:撤销历史中某次提交(非最后一次)

如果要撤销的不是最后一次提交,而是历史中的某次,推荐用 git revert(更安全,不会改写历史):

步骤 1:找到要撤销的提交 ID

先查看提交记录,找到目标提交的哈希值(前 6-8 位即可):

bash 复制代码
git log --oneline # 简洁展示提交记录,格式:[提交ID] [提交信息]

步骤 2:撤销指定提交(生成反向提交)

bash 复制代码
git revert 提交Id # 例如 git revert a1b2c3d4

执行后 Git 会自动生成一个新的提交,内容是 "撤销某次提交的修改",你需要填写提交信息并保存。

步骤 3:推送到远程仓库

bash 复制代码
git push origin 分支名

git revert 不会删除原有提交记录,只是新增一个反向提交,适合多人协作的公共分支,避免改写历史导致冲突

注意事项

  1. 如果远程仓库开启了 保护分支 (如 GitHub/GitLab 的 protected branch),需要先在仓库设置中临时关闭保护,或赋予自己强制推送的权限,才能执行 git push -f
  2. 若已撤销提交但想恢复,可通过 git reflog 查看所有操作记录,找到撤销前的提交 ID,执行 git reset --hard 提交ID 恢复。

情况3:撤销了本地最后一次提交,远端仓库不能强制提交

步骤 1:先恢复本地的提交记录(关键)

因为你已经用 git reset 撤销了本地最后一次提交,现在需要先把本地记录恢复到和远程一致的状态,才能进行后续操作:

bash 复制代码
git pull origin 分支名 # git pull origin main

执行后,你之前撤销的本地提交会被恢复,本地和远程的提交记录重新同步。

步骤 2:用 revert 撤销最后一次提交(生成反向提交)

git revert 会创建一个新的提交,这个提交的内容是 "撤销上一次提交的所有修改",相当于把最后一次提交的代码改回来,但不会删除原有提交记录(因此不需要强制推送):

bash 复制代码
# 撤销最后一次提交(HEAD 代表最新提交,HEAD~1 是上一次,这里直接用 HEAD 即可)
git revert HEAD

执行后会弹出提交信息编辑界面,默认信息是 Revert "你最后一次提交的备注",直接保存退出即可(一般按 Esc → 输入 :wq 回车)。

步骤 3:推送新的 revert 提交到远程

这一步是普通推送,不需要强制,因为只是新增了一个提交,完全符合远程仓库的规则:

bash 复制代码
git push origin 你的分支名  # 例如 git push origin main

示例演示

假设你的提交记录原本是:

tex 复制代码
提交C(最后一次,要撤销) → 提交B → 提交A

执行 git revert HEAD 后,会新增一个提交 D:

tex 复制代码
提交D(Revert 提交C) → 提交C → 提交B → 提交A
相关推荐
李日灐3 小时前
< 7 > Linux 开发工具:git 版本控制器 和 cgdb/gdb 调试器
linux·运维·服务器·开发语言·git·调试器·gdb/cgdb
Gust of wind3 小时前
idea结合git和Gitee的初步使用
git·gitee·intellij-idea
夜七少eleanor3 小时前
【Git】2026全图文详解安装教程
git
海边的Kurisu4 小时前
从零开始的Git生活 | 刚实习同学的噩梦 And 参与开源不可缺的一环
git·生活
不老刘5 小时前
Git Cherry-Pick:微前端架构下的“精准医疗”与最佳实践
前端·git
爬楼的猪5 小时前
Git Folder Dashboard
git
Uncertainty!!5 小时前
claude code中添加skills自动生成git commit信息
git·git commit·claude code
FserSuN7 小时前
Git Worktree 使用学习
git·学习
Z文的博客7 小时前
嵌入式LINUX QT 开发 .gitignore 文件编写指南
linux·git·qt·elasticsearch·嵌入式
前端双越老师8 小时前
3 个命令 7 个步骤,学会 git worktree 并行开发
git·ai编程·全栈