小编典典

撤消“git push”

all

这是我在我 应该是稳定的 分支上所做的......

% git rebase master
First, rewinding head to replay your work on top of it...
Fast-forwarded alpha-0.3.0 to master.
% git status
# On branch alpha-0.3.0
# Your branch is ahead of 'origin/alpha-0.3.0' by 53 commits.
#
nothing to commit (working directory clean)
% git push
Fetching remote heads...
  refs/
  refs/heads/
  refs/tags/
  refs/remotes/
'refs/heads/master': up-to-date
updating 'refs/heads/alpha-0.3.0'
  from cc4b63bebb6e6dd04407f8788938244b78c50285
  to   83c9191dea88d146400853af5eb7555f252001b0
    done
'refs/heads/unstable': up-to-date
Updating remote server info

我后来意识到这完全是一个错误。我想撤消这整个过程,并将 alpha-0.3.0 分支恢复到原来的样子。

我该怎么办?


阅读 146

收藏
2022-03-03

共1个答案

小编典典

您需要确保此存储库的其他用户没有获取不正确的更改或尝试在您想要删除的提交之上构建,因为您即将回滚历史记录。

然后你需要“强制”推送旧的参考。

git push -f origin last_known_good_commit:branch_name

或者在你的情况下

git push -f origin cc4b63bebb6:alpha-0.3.0

您可能已经receive.denyNonFastForwards在远程存储库上进行了设置。如果是这种情况,那么您将收到包含短语的错误[remote rejected]

在这种情况下,您将不得不删除并重新创建分支。

git push origin :alpha-0.3.0
git push origin cc4b63bebb6:refs/heads/alpha-0.3.0

如果这不起作用 -
可能是因为您已receive.denyDeletes设置,那么您必须直接访问存储库。在远程存储库中,您必须执行类似以下管道命令的操作。

git update-ref refs/heads/alpha-0.3.0 cc4b63bebb6 83c9191dea8
2022-03-03