我的仓库现在有 100 个提交。我需要回滚存储库以提交 80,并删除所有后续的。
为什么?
这个 repo 应该是为了从杂项用户合并。由于过度编辑,我提交了一堆合并。那是由于我的远程分支的标签错误,其中 3 个开发人员被标记为彼此。我需要重置到那个点,然后向前拉。
我想变基,如本例所示:How can I remove a commit on GitHub?
但是,git 希望我做很多冲突管理。有没有更简单的方法?
git reset --hard <old-commit-id>
git push -f <remote-name> <branch-name>
注意:正如下面评论中所写,在协作环境中使用它是危险的:你正在重写历史
要撤消最近的提交,我这样做:
第一的:
git log
获取最新的 SHA id 以撤消。
git revert SHA
这将创建一个与您的提交完全相反的新提交。然后你可以推送这个新的提交以使你的应用程序恢复到以前的状态,你的 git 历史记录将相应地显示这些更改。
这对于立即重做你刚刚提交的事情很有用,我发现这对我来说更常见。
正如迈克提到的,你也可以这样做:
git revert HEAD
git revert HEAD
将还原上次提交,而无需查找哈希。
另一种方式:
签出您要恢复的分支,然后将本地工作副本重置回您希望成为远程服务器上最新的提交(之后的一切都会再见)。为此,在 SourceTree 中,我右键单击并选择“将 BRANCHNAME 重置为此提交”。
然后导航到存储库的本地目录并运行以下命令:
git -c diff.mnemonicprefix=false -c core.quotepath=false push -v -f -- tags REPOSITORY_NAME BRANCHNAME:BRANCHNAME
这将删除本地存储库中当前提交之后的所有提交,但仅针对那个分支。
大多数建议都假设您需要以某种方式销毁最后 20 次提交,这就是为什么它意味着“重写历史”,但您不必这样做。
只需从提交 #80 创建一个新分支,然后继续处理该分支。其他 20 个提交将保留在旧的孤立分支上。
如果您绝对希望您的新分支具有相同的名称,请记住该分支基本上只是标签。只需将旧分支重命名为其他名称,然后在提交 #80 处使用您想要的名称创建新分支。
当从 master 进行分支更新时,我注意到我有时会过度点击,并导致分支也合并到 master 中。找到了一种方法来撤销它。
如果您的最后一次提交是合并,则需要更多的爱:
git revert -m 1 头
在 github 中,简单的方法是在 github UI 中的分支选项卡下删除远程分支。您必须确保删除以下设置以使分支可删除:
不是默认分支 没有开放投票请求。分支不受保护。
现在在本地存储库中重新创建它以指向上一个提交点。并将其添加回远程仓库。
git checkout -b master 734c2b9b # replace with your commit point
然后将本地分支推送到远程
git push -u origin master
添加回默认分支和分支保护等。
不定期副业成功案例分享
git push -f origin branch
。我只是度过了一段糟糕的时光,因为我错过了。git push origin HEAD --force
而不是git push -f origin branch
因为那给了我一个error: src refspec branch does not match any.
错误