git 如何撤销一次remote的master commit?

mopodo
  • 80

除了在local reset后再push之外 有没有在remote直接reset之类的呢? 意义是不想remote有过多commit comment

回复
阅读 29k
4 个回答

没有,只能 git reset --hard 然后 git push -f

你的问题询问的是如何撤销 remote 的 commit,唯一的办法就是本地修正然后又强制推送,并且很多人都已经提到,强制推送是非常坏的实践,除非必要或者个人未公开项目或者小团队项目(沟通成本较低)才可行。

看了你给别的回答的评论,貌似你想清理提交历史,那么 git 相比于其它 VCS 在这方面绝对是非常在行的。你可以使用 git rebase 命令对历史进行重构,可以重新排序、合并、拆分一些提交,总之完全足够清理你所谓的脏历史。如果你想要对整个历史做某些确定的修改,还有 git fileter-branch 命令可用,非常灵活,相当值得深入。

说说我的提交流程吧,我一般是对一个文件进行修改直到达到我的目的后才开始进行提交,这个时候我也不是只直接做一次提交,而是使用 vim 和 vim-fugitive 插件,在 diff 模式下打开工作区和暂存区,然后在暂存区重新一步一步的重现我的修改,在适当的时候进行提交。由于我已经完成了整个修改,所以我很清楚每个修订该谁先谁后,所以能够做到比较干净清晰和“原子性”(即一个提交只做一个特定的修改,而不是混合若干个修改)的提交,方便其他人进行代码审阅。

——————

最后,希望注意,SF 不同于国内的论坛模式,不是一问一答再问再答的方式。如果你觉得需要补充你的问题,直接修改问题即可,这样所有关注的人都会得到通知。如果你只在别的回答的评论里面进行问题的更新和补充,没有人会得到通知的。

我的做法是本地回滚到正确的版本,然后在push一次,如果要消除之前的那次提交记录,貌似要用git rebase

请认真对待上传到网上的东西. 那都是历史, 要尊重历史, 你可以在本地随便调戏你的记录. 一旦你将他发布, 他就会成为互联网上的历史, 必须要尊重的历史.

折腾了半天我就是想说, 上传之后就不应该更改了. 你这个想法是有问题的.

宣传栏