1. 简介

git revert 用于撤销部分现有提交。

git revert 不会删除历史提交记录,会用一个新的提交来消除历史提交所做的修改。新提交的内容是“反向”的——即撤销指定提交所引入的变更。

git reset 不同,git revert安全的,因为它不修改历史,适合用于已推送到远程仓库的公共分支

典型场景:

  • 撤销已经推送到远程的提交
  • 撤销公共分支(如 main)上的错误提交
  • 需要保留完整历史记录的场景

2. 格式

git revert [<options>] <commit>...
git revert (--continue | --skip | --abort | --quit)

3. 选项

-n, --no-commit
  只暂存撤销的变更,不自动提交(可继续修改或添加其他变更)

-e, --edit
  在提交前编辑提交信息(默认行为)

--no-edit
  不编辑提交信息,直接使用自动生成的默认信息

-m, --mainline=<parent-number>
  指定撤销合并提交时,保留哪个父分支(1 或 2)

--no-commit
  只将变更放入暂存区,不自动提交

--signoff
  在提交信息末尾添加 Signed-off-by 行

--continue
  解决冲突后继续 revert

--skip
  跳过当前提交

--abort
  放弃 revert,恢复到操作前的状态

--quit
  忘记并中断:放弃当前的 revert 操作,但保留工作区和暂存区当前的修改(即冲突解决了一半的状态)

4. 示例

4.1 撤销单个提交

# 撤销最近一次提交(会打开编辑器让你修改提交信息)
git revert HEAD

# 撤销指定提交,然后生成一个新的提交
git revert a1b2c3d

# 使用默认提交信息,不编辑
git revert --no-edit a1b2c3d

4.2 撤销多个提交

# 撤销多个提交(按顺序从新到旧)
git revert a1b2c3d e5f6g7h

# 撤销一段范围(不包含 A,包含 B)
git revert A..B

4.3 撤销合并提交

# 撤销合并提交,需要指定保留哪个父分支
# -m 1:保留第一个父分支(通常是主分支)
git revert -m 1 a1b2c3d

4.4 只暂存不提交

# 只将撤销的变更加入暂存区,不自动提交
git revert -n a1b2c3d

4.5 解决冲突

# revert 时产生冲突
git revert a1b2c3d
# CONFLICT in main.go

# 手动解决冲突后
git add main.go
git revert --continue

# 或者放弃 revert
git revert --abort

5. 注意

5.1 git revert vs git reset 对比

对比维度 git revert git reset
是否改变历史 ❌ 否(创建新提交) ✅ 是(删除提交)
是否安全用于公共分支 ✅ 是 ❌ 否(会改写历史)
撤销方式 增加反向提交 删除提交
适用场景 已推送的公共分支 本地未推送的分支

与 git reset 的区别主要有:

  • 实现的方式不用。

git revert 使用一次新的提交来回退到指定版本,不会改变历史的提交历史。git reset 移动 HEAD 指针指向历史某次提交,历史提交记录将被改变。因此,git revert 一般用在公共分支上,git reset 一般用在私有分支上。

  • 使用的场景不同。

git revert 一般只用于版本回退,撤销已经提交的更改,并且要求暂存区与工作区是干净的。git reset 一般用于撤销未提交的修改,比如使用 git reset --hard 放弃暂存区与工作区的修改。

5.2 revert 多个提交的顺序

# revert 多个提交时,按从新到旧的顺序
git revert HEAD~2 HEAD~1 HEAD
# 等价于先 revert 最新的,再 revert 次新的

5.3 revert 合并提交的特殊性

# 合并提交有两个父提交,必须用 -m 指定保留哪个
# 查看合并提交的两个父分支
git show a1b2c3d

# 一般 -m 1 表示保留当前分支(目标分支)
git revert -m 1 a1b2c3d

5.4 撤销 revert(恢复被撤销的提交)

# 如果 revert 错了,可以直接 revert 这个 revert 提交
git revert <revert-commit>

5.5 常用别名设置

git config --global alias.rv "revert --no-edit"
git config --global alias.rvc "revert --continue"

# 使用别名
git rv a1b2c3d
git rvc

6. 小结

需求 命令 说明
撤销最近一次提交 git revert HEAD 创建反向提交
撤销指定提交 git revert a1b2c3d 撤销该提交的修改
撤销多个提交 git revert a1b2c3d e5f6g7h 按从新到旧的顺序
撤销合并提交 git revert -m 1 a1b2c3d 必须指定 -m 参数
使用默认提交信息 git revert --no-edit a1b2c3d 不打开编辑器
解决冲突后继续 git add . && git revert --continue 继续 revert
放弃 revert git revert --abort 恢复到操作前

一句话总结git revert安全撤销的命令,它不删除历史,而是创建反向提交。适合撤销已推送到远程的公共分支。撤销合并提交时必须用 -m 指定保留哪个父分支。


参考文献

Git - git-revert Documentation

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐