我“不小心”向GitHub推送了一个提交。

是否可以删除此提交?

我想恢复提交之前的GitHub存储库。


当前回答

你需要从你想要还原的提交中知道你的提交哈希。你可以从GitHub URL获取它,比如:https://github.com/your-organization/your-project/commits/master

假设提交的哈希(您要返回的位置)为“99fb454”(长版本“99fb 45413eb9ca4b3063e07b40402b136a8cf264”),那么您需要做的就是:

git reset --hard 99fb45413eb9ca4b3063e07b40402b136a8cf264
git push --force

其他回答

注意:请在下面的评论中看到gitrebase-i的替代方案-git reset—软头^

首先,删除本地存储库中的提交。您可以使用gitrebase-i来执行此操作。例如,如果是最后一次提交,可以执行gitrebase-i HEAD~2并在弹出的编辑器窗口中删除第二行。

然后,使用gitpushorigin+branchName--force强制推送到GitHub

有关更多信息,请参见Git Magic第5章:历史教训-然后是一些(例如,如果您想删除旧的提交)。

哦,如果你的工作树很脏,你必须先做一个git存储,然后再应用git存储。

git push -f origin HEAD^:master

这应该会“撤销”推送。

添加/删除文件以获得所需的内容:

git rm classdir
git add sourcedir

然后修改承诺:

git commit --amend

之前的错误提交将被编辑以反映新的索引状态-换句话说,这就像您一开始就没有犯过错误一样

请注意,只有当您还没有按下时,才应该执行此操作。如果您已经推送,那么您只需正常提交修复。

git reset HEAD^ --hard
git push origin -f

这对我有用。

在Github上找到你想成为分支负责人的提交的参考规范,并使用以下命令:

git推送原点+[ref]:[branchName]

在您的情况下,如果您只想返回一次提交,请查找该提交的ref的开头,例如它是7f6d03,以及要更改的分支的名称,例如它为master,然后执行以下操作:

git推送原点+7f6d03:主

加号被解释为--force,这是必要的,因为您正在改写历史。

请注意,任何时候你强制提交,都可能会改写合并你分支的其他人的历史。然而,如果你很快发现了问题(在其他人合并你的分支之前),你就不会有任何问题。