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 创建一个新的修复提交,而不是直接回退历史记录。
  • 在执行任何操作之前,请务必备份远程仓库,并与团队充分沟通。
相关推荐
ityangs7 小时前
GitLab 私服(基于 Docker)搭建方案
git·docker·容器·gitlab
ZYMFZ11 小时前
Redis主从复制与哨兵集群
前端·git·github
三体世界17 小时前
Qt从入门到放弃学习之路(1)
开发语言·c++·git·qt·学习·前端框架·编辑器
汤面不加鱼丸18 小时前
git常用指令
git
秦jh_1 天前
【git】基本操作
git
徐同保1 天前
Arguments: ls-remote --tags --heads git://github.com/adobe-webplatform/eve.git
git·adobe·github
北塔软件1 天前
各品牌服务器IPMI配置实战经验分享
服务器·git·github
一只小bit2 天前
Git 远程操作:克隆、推送、拉取与冲突解决
数据库·git·github
__Witheart__2 天前
.gitignore 不生效问题——删除错误追踪的文件
git
月临水2 天前
Git 学习笔记
笔记·git·学习·1024程序员节