如何在git中回滚到特定的提交?
有人能给我的最好答案是使用git恢复X次,直到我达到所需的提交。
假设我想要恢复到20次提交前的提交,我需要运行20次。
有更简单的方法吗?
我不能使用重置,因为这个存储库是公共的。
如何在git中回滚到特定的提交?
有人能给我的最好答案是使用git恢复X次,直到我达到所需的提交。
假设我想要恢复到20次提交前的提交,我需要运行20次。
有更简单的方法吗?
我不能使用重置,因为这个存储库是公共的。
当前回答
这里有一个例子
cd /yourprojects/project-acme
git checkout efc11170c78 .
其他回答
想要HEAD分离模式?
如果你希望回滚X次到一个带有DETACHED HEAD的特定提交(意味着你不能搞砸任何事情),那么无论如何,使用以下方法:
(将X替换为您希望返回的提交次数)
git checkout HEAD~X
即返回一次提交:
git checkout HEAD~1
git read-tree -um @ $commit_to_revert_to
我会做的。它是“git checkout”,但没有更新HEAD。
你可以达到同样的效果
git checkout $commit_to_revert_to
git reset --soft @{1}
如果您喜欢将方便的命令串在一起。
这将使你的工作树和索引处于所需的状态,你可以git提交完成。
这里有一个例子
cd /yourprojects/project-acme
git checkout efc11170c78 .
假设你在做一个项目,过了一天左右。您注意到有一个特性仍然出错。但是你不知道你做了什么改变导致了错误。所以你必须找出以前的工作提交。恢复到特定的提交:
git checkout 8a0fe5191b7dfc6a81833bfb61220d7204e6b0a9 .
好的,这个commit对你有用。不会再有错误了。你指出了问题所在。现在你可以回到最近的提交:
git checkout 792d9294f652d753514dc2033a04d742decb82a5 .
在导致错误之前签出一个特定的文件(在我的例子中,我使用Gemfile.lock):
git checkout 8a0fe5191b7dfc6a81833bfb61220d7204e6b0a9 -- /projects/myproject/Gemfile.lock
这是一种处理在提交中创建的错误的方法,直到以后才会意识到这些错误。
你可以在GitHub/BitBucket/Gitlab的提交部分找到与每个提交相关的提交id。 这很简单,假设你的提交id是5889575,那么如果你想回到代码中的这一部分,那么你只需要输入
git checkout 5889575 .
这将带您到代码中的那个时间点。