我在远程存储库中有一个项目,与本地存储库(开发)和服务器存储库(prod)同步。我一直在做一些已经推送到远程和从服务器上拉出来的承诺更改。现在,我想撤销这些更改。因此,我可以在更改之前签出到提交,并提交新更改,但我猜再次将它们推到远程会有问题。我该怎么做,有什么建议吗?
当前回答
这将删除您推送的提交
git reset --hard 'xxxxx'
git clean -f -d
git push -f
做个备份以防万一
评论中出现了两个注释:
'xxxxx'是你想保留的最后一次提交的哈希码。 清洁是危险的。它删除文件,不受版本控制!
其他回答
你可以通过以下方法恢复单个提交:
git revert <commit_hash>
这将创建一个新的提交,该提交将恢复您指定的提交的更改。请注意,它只恢复特定的提交,而不恢复之后的提交。如果你想要还原一系列的提交,你可以这样做:
git revert <oldest_commit_hash>..<latest_commit_hash>
它将还原<oldest_commit_hash>之后直到<latest_commit_hash>的所有提交。在某些版本的git上,它还会恢复<oldest_commit_hash>,因此请仔细检查该提交是否被恢复。您总是可以使用g reset—hard HEAD~来删除最新的恢复提交(它恢复了最早的提交)。
要找出提交的哈希值,可以使用git log。
有关git revert命令的更多信息,请参阅git-revert手册页。此外,查看这个答案,了解关于恢复提交的更多信息。
一种不保留“撤销”痕迹的解决方案。
注意:如果有人已经抽取了您的更改,则不要这样做 (我只会在个人回购时使用这个方法。)
run:
git reset <previous label or sha1>
这将在本地重新签出所有更新(因此git状态将列出所有更新的文件)
然后你“做你的工作”并重新提交你的更改(注意:这一步是可选的)
git commit -am "blabla"
此时,您的本地树与远程树不同
git push -f <remote-name> <branch-name>
将强制远程分支接受此推送并删除前一个推送(指定remote-name和branch-name不是强制的,但建议避免更新带有update标志的所有分支)。
!! 注意一些标签可能仍然指向删除提交!!how-to-delete-a-remote-tag
这将删除您推送的提交
git reset --hard 'xxxxx'
git clean -f -d
git push -f
做个备份以防万一
评论中出现了两个注释:
'xxxxx'是你想保留的最后一次提交的哈希码。 清洁是危险的。它删除文件,不受版本控制!
git revert HEAD -m 1
在上面的代码行。"最后一个参数表示"
1 -还原一次提交。 2 -返回最近两次提交。 N -返回上一个N 提交。
该命令后需要按一下才能对远程生效。您还有其他选项,例如指定要恢复的提交范围。这是选项之一。
稍后使用git commit -am "COMMIT_MESSAGE" 然后是git push或git push -f
Git重置<commit_hash>(获取<commit_hash>使用Git log——oneline)
Git恢复。将所有更改的文件恢复到yout目标提交的版本
Git push origin master——force强制推到远程主分支。但如果有人和你在同一分支工作,在使用力推时要小心
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别