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
相关推荐
siqiangming16 小时前
将SVN项目迁移到Git,保留提交记录
git·svn
CCPC不拿奖不改名16 小时前
两种完整的 Git 分支协作流程
大数据·人工智能·git·python·elasticsearch·搜索引擎·自然语言处理
南方者16 小时前
【Sourcetree】【Git】提交后无法推送,优雅回滚
git·版本管理·sourcetree·回滚·贮藏
lpfasd12317 小时前
PyGithub用法详解
git·python·github
一品威客网19 小时前
版本控制(Git):APP协同开发的四大核心基石
大数据·git
007张三丰20 小时前
git中的SSH 公钥配置详细指南(GitHub、GitLab、Gitee平台适用)
git·ssh·github
yue00821 小时前
git使用
git
tianlebest21 小时前
git action
大数据·git·elasticsearch
花间相见1 天前
【JAVA开发】—— Git常用操作
java·开发语言·git