我“不小心”向GitHub推送了一个提交。
是否可以删除此提交?
我想恢复提交之前的GitHub存储库。
我“不小心”向GitHub推送了一个提交。
是否可以删除此提交?
我想恢复提交之前的GitHub存储库。
当前回答
如果您希望在删除后保留提交更改:
请注意,如果要删除的提交是最后一次提交的提交,则此解决方案有效。
1-从日志中复制要返回的提交引用:
git log
2-将git重置为提交引用:
git reset <commit_ref>
3-保存/存储错误提交的本地更改,以便在推送到远程后稍后使用:
git stash
4-将更改推送到远程存储库(-f或--force):
git push -f
5-将存储的更改恢复到本地存储库:
git stash apply
7-如果您在更改中有未跟踪的/新的文件,您需要在提交之前将它们添加到git中:
git add .
6-添加所需的任何额外更改,然后提交所需的文件(或使用点“.”而不是声明每个文件名),以提交本地存储库中的所有文件:
git commit -m "<new_commit_message>" <file1> <file2> ...
or
git commit -m "<new_commit_message>" .
其他回答
您需要清除缓存以将其完全清除。git的这个帮助页面将帮助您。(这对我有帮助)http://help.github.com/remove-sensitive-data/
要从远程存储库中删除提交,请执行以下操作:
git push -f origin last_known_good_commit:branch_name
要从本地存储库中删除提交,请执行以下操作:
git reset --hard HEAD~1
link
如果您希望在删除后保留提交更改:
请注意,如果要删除的提交是最后一次提交的提交,则此解决方案有效。
1-从日志中复制要返回的提交引用:
git log
2-将git重置为提交引用:
git reset <commit_ref>
3-保存/存储错误提交的本地更改,以便在推送到远程后稍后使用:
git stash
4-将更改推送到远程存储库(-f或--force):
git push -f
5-将存储的更改恢复到本地存储库:
git stash apply
7-如果您在更改中有未跟踪的/新的文件,您需要在提交之前将它们添加到git中:
git add .
6-添加所需的任何额外更改,然后提交所需的文件(或使用点“.”而不是声明每个文件名),以提交本地存储库中的所有文件:
git commit -m "<new_commit_message>" <file1> <file2> ...
or
git commit -m "<new_commit_message>" .
要保留分支和合并结构,在执行重基时使用--preserve merges选项非常重要:
git rebase --preserve-merges -i HEAD^^
对于GitHub
在本地存储库中重置提交(HARD)创建新分支推送新分支删除旧分支(如果要删除主分支,请将新分支作为默认分支)