假设我有一个这样的图
A---B---C---D (master)
\
\-E---F (HEAD)
如果我执行git log -all - online,我将得到所有6次提交。
但如果图像是
A---B---C---D (master, HEAD)
\
\-E---F
我不会看到E和f。我能得到git告诉我所有的提交,包括那些没有命名的分支吗?
谢谢
假设我有一个这样的图
A---B---C---D (master)
\
\-E---F (HEAD)
如果我执行git log -all - online,我将得到所有6次提交。
但如果图像是
A---B---C---D (master, HEAD)
\
\-E---F
我不会看到E和f。我能得到git告诉我所有的提交,包括那些没有命名的分支吗?
谢谢
当前回答
救了我一命的是下面的命令:
git reflog
在这里你会发现一个历史提交完成的屏幕,就像这样:
在这一点上,你只需要找到你需要的HEAD@{X},创建一个临时分支,并像这样移动到它:
git checkout -b temp_branch HEAD@{X}
这样你就会有一个临时的分支来处理你丢失的提交,而不会重基或者破坏你的git存储库。
希望这对你有所帮助……
其他回答
当我解决这个问题时,我使用以下命令:
git reflog | awk '{ print $1 }' | xargs gitk
这让我可以可视化最近已经变成无头的提交。
我把这个包在一个名为~/bin/git-reflog-gitk的脚本帮助器中。
编辑:-我的git-reflog-gitk包装是多余的-因为你现在可以直接调用gitk -reflog
不是很容易——如果你把指针弄丢了,那就像大海捞针一样。你可以找到所有看起来不再被引用的提交- git fsck -unreachable将为你做这件事-但这将包括你在git提交后扔掉的提交- modify,你重新基于的分支上的旧提交等等。因此,一次查看所有这些提交很可能有太多的信息,难以处理。
所以轻率的回答是,不要忘记你感兴趣的东西。更严重的是,reflogs将默认保存您在过去60天左右使用过的所有提交的引用。更重要的是,它们将提供关于这些提交是什么的上下文。
如果你使用Git Extensions GUI,如果你选择“View -> show reflog references”,它可以显示一个悬浮提交的图形可视化。 这将显示树中的悬空提交,就像所有其他引用的提交一样。这样更容易找到你要找的东西。
请参见此图像进行演示。图像上的提交C2, C3, C4和C5是悬空的,但仍然可见。
我怎么解决这个问题?使用git fsck和日志!
首先创建一个包含丢失(不可达)提交和blob的文件。(注意:如果你做了像git gc这样的事情,那么它会垃圾收集所有提交的文件,你在这里找不到它们!)
$git fsck --lost-found > lost_found.commits
它会给你一个这样的文件:
悬空提交dec2c5e72a81ef06963397a49c4b068540fc0dc3 悬浮blob f8c2579e6cbfe022f08345fa7553feb08d60a975 悬挂blob 0eb3e86dc112332ceadf9bc826c49bd371acc194 悬挂blob 11cbd8eba79e01f4fd7f496b1750953146a09502 悬空提交18733e44097d2c7a800650cea442febc5344f9b3 悬挂blob 1e53a5cdb3ecdde27081ec6e8b31e4070106ee05
然后,您可以使用您喜欢的文本编辑器打开该文件,从那里复制提交/博客哈希值。(*咳嗽* vim宏工作为这个*咳嗽*)
现在你可以用git log——oneline <commit hash>之类的东西从这个提交中返回日志。 或者,gitk, tig或任何其他git查看器都可以工作。
在你的例子中,如果你找到提交F的哈希,日志会显示这样的东西,
A---B---E---F
又快又简单!现在您可以找到所有这些悬空提交背后的上下文。
附注:是的,我知道,很晚了,但哦,好吧,有人可能会在这里找到它,并发现它很有用。(很可能是我在6个月后再次谷歌这个)
通过查看reflog(位于.git/logs/HEAD),我已经幸运地恢复了提交
然后我不得不向下滚动到文件的末尾,我找到了刚刚丢失的提交。