GIT 撤销上次推送

注意:在执行下述操作之前先备份现有工作进度,如果不慎未保存,在代码编辑器中正在修改的文件下,使用Ctrl+Z 撤销试试

撤销推送的方法

情况 1:您刚刚推送到远程仓库

如果您的推送操作刚刚完成,并且没有其他开发者在此期间提交新的更改,可以使用以下方法撤销推送。

方法 1:强制推送回退到之前的提交

1 找到推送前的最后一次提交的哈希值 使用以下命令查看提交历史,找到推送前的最后一次提交的哈希值(例如 abc1234):

bash 复制代码
git log --oneline

2 强制推送回退到指定提交 使用以下命令将远程分支强制回退到指定提交:

bash 复制代码
git push origin <commit-hash>:<branch-name> --force

示例:

bash 复制代码
git push origin abc1234:master --force

这会将远程分支 master 的状态回退到提交 abc1234

方法 2:重置本地分支并强制推送

1 重置本地分支到推送前的状态 如果您已经知道推送前的最后一次提交的哈希值(例如 abc1234),可以使用以下命令重置本地分支:

bash 复制代码
git reset --hard <commit-hash>

示例

bash 复制代码
git reset --hard abc1234

2 强制推送重置后的分支 将本地分支的状态强制推送到远程仓库:

bash 复制代码
git push origin --force
情况 2:其他开发者已经基于此推送进行了工作

如果其他开发者已经基于您错误推送的提交进行了工作,直接撤销推送可能会导致他们的工作丢失。在这种情况下,您需要采取更谨慎的方式:

  1. 与团队沟通

    • 通知团队成员暂停对相关分支的工作。
    • 确保所有人都了解即将进行的回退操作。
  2. 创建一个新的修复提交 而不是直接回退历史记录,可以通过创建一个新的提交来修复问题:

bash 复制代码
# 撤销最近一次提交,但保留更改
git revert HEAD
  • 这会在当前分支上创建一个新的提交,用于撤销最近一次提交的更改。
  • 推送这个新的提交到远程仓库:
bash 复制代码
git push origin master

注意事项

1 备份远程仓库

  • 在执行任何回退或撤销操作之前,请确保备份远程仓库的状态(例如通过克隆或导出)。
  • 如果远程仓库支持镜像克隆,可以使用以下命令备份:
bash 复制代码
git clone --mirror <HTTPS链接>

2 保护分支规则

  • 如果远程仓库启用了分支保护规则(如禁止强制推送),您需要先禁用这些规则,或者联系管理员协助完成操作。

3 协作开发的影响

  • 强制推送会改变远程分支的历史记录,可能会影响其他开发者的本地分支。
  • 其他开发者需要重新同步远程分支的状态,例如通过以下命令:
bash 复制代码
git fetch origin
git reset --hard origin/master

4 超大文件的后续处理

  • 如果您因为超大文件的问题而需要撤销推送,请在回退后彻底清理该文件的历史记录(参考之前的回答)。
  • 确保后续不再将超大文件提交到仓库中。

总结

  • 如果您刚刚推送到远程仓库并且没有其他开发者参与,可以直接通过 git resetgit push --force 撤销推送。
  • 如果其他开发者已经基于错误推送进行了工作,建议通过 git revert 创建一个新的修复提交,而不是直接回退历史记录。
  • 在执行任何操作之前,请务必备份远程仓库,并与团队充分沟通。
相关推荐
LCY1331 小时前
spring 中的DAO是什么
运维·git·jenkins
柚几哥哥4 小时前
IntelliJ IDEA全栈Git指南:从零构建到高效协作开发
java·git·intellij-idea
遇到困难睡大觉哈哈4 小时前
Git推送错误解决方案:`rejected -> master (fetch first)`
大数据·git·elasticsearch
ON.LIN4 小时前
Git提交本地项目到Github
git·github
九月镇灵将5 小时前
6.git项目实现变更拉取与上传
git·python·scrapy·scrapyd·gitpython·gerapy
wuyijysx5 小时前
ubuntu git cola gui
git·软件工具
九月镇灵将6 小时前
GitPython库快速应用入门
git·python·gitpython
程序猿chen7 小时前
《JVM考古现场(十五):熵火燎原——从量子递归到热寂晶壁的代码涅槃》
java·jvm·git·后端·java-ee·区块链·量子计算
前端三叶草11 小时前
git subtree 最佳实践
git
Code_Geo12 小时前
Git操作指南
git