[英]How to undo a merge on Bitbucket?
我创建了一个现在位于 Bitbucket 存储库上的合并(到“主”分支)。 长话短说:我需要撤消该合并。
我知道您可以在 Github 站点本身执行此操作,但 Bitbucket 没有该功能。 我不清楚如何在不造成混乱的情况下使用 Git 做到这一点。
您需要首先克隆本地系统上的存储库(您可以从Bitbucket中存储库的“Overview”页面获取SSH或HTTPS格式的repo URL):
git clone git@bitbucket.org:my/repo.git
-or-
git clone https://my@bitbucket.org/my/repo.git
git checkout master
..然后恢复最近的提交。 首先列出可用的提交:
git log
..然后在合并之前选择提交:
git reset --hard 72ead1c4c1778c23c277c4f15bbb68f3bb205f54
..其中哈希是合并之前提交的哈希值(来自日志)。 最后,强制将更改推回Bitbucket,覆盖历史记录。
git push -f
当然,如果回购共享,并且其他用户已经撤回了您最近的提交并在其上构建,他们将不会高兴。 因此,在这种情况下,请务必通知所有人您正在做的事情。
如其他答案所述, revert
是另一种选择; 它会保留您所做的提交,但会进一步修改存储库(使用新的提交),以便撤消您所做的更改。 是否要使用revert
取决于您是否希望提交中的信息保留在repo历史记录中。
有关撤消git中的更改的更多详细信息,请参阅Atlassian的一个很好的教程页面 。
2017年,Bitbucket实施了“恢复请求”功能。
要恢复拉取请求:
资料来源: 文档 。
我建议做一个revert
,因为你正在恢复一个公共回购。
git revert HEAD
git push -f origin
撤消提交的更改: git revert <commit id>
首先,在您的本地机器上,在您合并到的分支上(例如master
):
git revert -m 1 HEAD
或者:
git revert -m 1 <merge commit hash>
然后推到原点。
或者,如果您不能直接推送到 master,请在恢复之前先从 master 上创建一个新分支,然后使用这个新分支推送并创建一个新的 PR 并针对 master 并在 bitbucket 上合并。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.