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
相关推荐
caicai_xiaobai23 分钟前
Ubuntu上Git安装步骤
linux·git·ubuntu
come112341 小时前
git 区分是 Git 分支还是 worktree 路径名
git
憧憬成为java架构高手的小白2 小时前
git多人工作之个人规范使用【ai+个人理解】
git
CVer儿2 小时前
git简单操作
git
Andya_net2 小时前
Git | Git 核心命令深入解析:从原理到实战
大数据·git·elasticsearch
wh_xia_jun3 小时前
给小白的 Maven 命令行执行测试 完整指南
git·maven·intellij-idea
专业白嫖怪3 小时前
H3C UniServer R4950 G5 服务器压测实战:13根内存条24小时压力测试全流程
git
我先去打把游戏先4 小时前
Ubuntu虚拟机(服务器版本)Git安装教程(附常用命令)——从零开始掌握版本控制
服务器·c语言·c++·git·嵌入式硬件·物联网·ubuntu
咸鱼永不翻身4 小时前
Git Hooks 功能与作用详解
git·git-hooks·git钩子
闪电悠米4 小时前
黑马点评短信登录01_session_sms_login
java·spring boot·redis·git·spring·面试