[英]How to push "undo pushed commit" using command line?
编辑:好的,所以我解决了。 问题是我如何陈述分支名称。 它应该是git push -f origin card-editor
而不是git push -f origin/card-editor
。 谢谢。
大多数时间我使用 git,我使用 sourcetree。 除非发生“大灾难”的事情。 这是其中一种情况(对我而言)。 长话短说,我做了一个提交和推送,但现在我想在本地撤消它,以及在远程撤消它。
我从这里开始学习教程。 我成功地reset --hard
到最后一次好的提交。 现在只需要将它推送到服务器即可。
本教程的方式看起来非常简单。
git push -f branchname
我的功能分支远程名称是“card-editor”。 所以我做到了。
git push -f card-editor
但是我收到错误消息说“card-editor”似乎不是 git 存储库。
我用git branch -r
列出了我的分支列表。
origin/HEAD -> origin/master
origin/card-editor
origin/development
origin/staging
origin/production
好吧,所以我认为分支名称是origin/card-editor
。 所以我重试了。
git push -f origin/card-editor
但它仍然显示“origin/card-editor”似乎不是 git 存储库。
我的方法有什么问题? 我不认为这里需要做一些特别的事情吗? 我不是特别精通Git,尤其是控制台命令,因为通常我使用sourcetree来管理它。
如果您真的已经将不需要的提交推送到远程,那么这里最安全的方法是还原提交:
# assuming the unwanted commit is on the top of the branch
git revert HEAD
git push origin master
命令git revert
添加了一个新的提交,它在功能上撤消了您的提交引入的任何更改。 这种方法比git reset
更安全,因为后者会重写历史记录,因此一旦提交已经被推送到远程,就不适用了。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.