我知道这是在改写历史,很糟糕。
但是如何从远程分支永久删除少数提交?
我知道这是在改写历史,很糟糕。
但是如何从远程分支永久删除少数提交?
当前回答
有时,修复这个问题最简单的方法是从您知道代码良好的地方创建一个新的分支。然后,您可以不去管错误的分支历史记录,以防稍后需要从中挑选其他提交。这也确保您不会丢失任何提交历史记录。
来自你当地的错误分支:
git log
复制你想要分支所在的提交哈希并退出git日志
git checkout theHashYouJustCopied
git checkout -b your_new_awesome_branch
现在你有了一个你想要的新分支。
如果你还需要从错误的分支中保留一个特定的提交,而它不在你的新分支上,你可以选择你需要的特定提交:
git checkout the_errant_branch
git log
复制你需要拉入好的分支的提交哈希并退出git日志。
git checkout your_new_awesome_branch
git cherry-pick theHashYouJustCopied
拍拍自己的背。
其他回答
这可能是太少也太迟了,但帮助我的是听起来很酷的“核”选项。基本上,使用命令filter-branch,你可以在整个git历史记录中删除文件或更改大量文件。
这里最好解释一下。
TL:博士;
n . git switch -C branch_name origin/branch_name~ Git push—force
完成后,远程分支将被n次提交还原。
解释:
使用git开关,按n次提交重置分支。c选项将强制创建具有相同名称的新分支。 将branch_name替换为分支名称, 将n(在命令的末尾)替换为要恢复的提交数。 命令1:git switch -C branch_name origin/branch_name~n 例如:git switch -C feature/dashboard origin/feature/dashboard~1 //返回dashboard分支的1次提交。 强制推送局部更改 命令#2:git push——force
提示:要撤消已提交(未推送)的更改,git将重置HEAD~
git reset --soft commit_id
git stash save "message"
git reset --hard commit_id
git stash apply stash stash@{0}
git push --force
重要提示:确保你在“git push -f”上指定了哪些分支,否则你可能会无意中修改其他分支!(*)
本教程中显示了三个选项。以防链接中断,我将把主要步骤留在这里。
恢复完整的提交 删除最后一次提交 从列表中删除提交
1恢复完整提交
git revert dd61ab23
2删除上次提交
git push <<remote>> +dd61ab23^:<<BRANCH_NAME_HERE>>
或者,如果分支在本地可用
git reset HEAD^ --hard
git push <<remote>> -f
在+ dd61…是你的提交哈希,git将x^解释为x的父节点,+解释为强制的非快进推。
3从列表中删除提交
git rebase -i dd61ab23^
这将打开一个编辑器,显示所有提交的列表。删除你想要删除的那个。完成rebase和推力回购。
git rebase --continue
git push <remote_repo> <remote_branch> -f
我喜欢用rebase来做这个。 下面的n是最后的n次提交。如果你想删除第三个,用3替换n。
git rebase -i HEAD~n
然后,在清单中找到所需的提交,并将其从“pick”更改为“drop”。退出rebase并使用git push和“-f”选项,就像你刚刚做了一个rebase一样。