恢复在执行错误的git reset --hard命令后丢失的文件

4

这需要一个专家来解决:

我运行了git initgit add --all,在我意识到我没有设置git仓库之前,我已经在一个新项目上工作了很长时间。在运行git add之后,我意识到我忘记创建.gitignore文件。没有考虑清楚,我运行了git reset --hard HEAD,结果我的所有文件都消失了,没有日志或reflog,也没有状态,所有命令都会出现fatal: bad default revision 'HEAD'的错误提示。我确定答案是我完蛋了。似乎无法对任何悬空的blob等进行任何操作。希望有一些大牛知道我不知道的东西。

git fsck --full git:master
notice: HEAD points to an unborn branch (master)
Checking object directories: 100% (256/256), done.
notice: No default references
dangling blob c57eff55ebc0c54973903af5f72bac72762cf4f4
dangling blob 4740a6ee5099aa087bac317337e28bba78c4b83c
missing tree 4b825dc642cb6eb9a060e54bf8d69288fbee4904
dangling blob 0d6b3be3e5517a7a7df7df941a6bd3740fcfc5e1
dangling blob d0437745b1902b1ec7e4154a6c058a900575ae7b
dangling blob 5223f05f29bed36037a68f1185f0d718f2a5f9b8
dangling blob d3f186be7e3fcac86aa15c6ebf416f636269f356
dangling blob 526b432e210b3a943df9a7146a0fb4c3e30fc2f5
dangling blob 96722f502f9bd93e5205ea07d8c9b56b11f2e9bd
dangling blob 594eff1d8bfd71561f4f9a0b1447c764e812e2aa
dangling blob df1b87ad781e0a961648f2c01d37b9fe15e581bd
dangling blob e196d0eaf4df52ec1d65faf1971e444d37640284
dangling blob a112aeec073daabfa02ba34b97f14a2bed7ff831
dangling blob e449375c07fc16d823fda51632ed0ed9894ff0f7
dangling blob 67d6eb75cb856092664d32c6eb9c10e1e226d61a
dangling blob abecf6b29f407556dc135523dd68d889d1e5147e
dangling blob af384fede44e1cf5dd963988a6aedf3161089891
dangling blob 2f21e52fb10e12a249ee3c99cf386fcf4a3bb08c
dangling blob f12933a0ea1ff0f052eef393485d59e5400f4d40
dangling blob 72f3fb0e59445ddf270882b4d323daee85d7fe2b
dangling blob f5bffa99c3301776fe0634ac7982c15320c46207
dangling blob fd764a7e888b3e090bdff5604576de1ab28e0ef8

有趣的是,你得到了一个“缺失树4b825dc642cb6eb9a060e54bf8d69288fbee4904”:这是空树的哈希ID(参见https://dev59.com/UGkw5IYBdhLWcg3wm74h)。 - torek
是的...很奇怪。我只是将二进制数据转储到.txt文件中,并手动重新创建了我的文件结构,幸运的是由于内容量较小,这相对容易些。 - Kevin
1个回答

6
你仍然可以恢复内容!
为了安全起见,首先执行以下操作:
git fsck --lost-found

这将把blob保存到.git/lost-found/other

通过git fsck的输出,您现在可以执行以下命令:

git show c57eff55ebc0c54973903af5f72bac72762cf4f4 > filename

恢复文件操作是为了能够获取文件内容,但不能获取文件名。

你可以通过一个简单的命令对所有blob执行此操作,如下:

for blob in $(git fsck --lost-found | awk '$2 == "blob" { print $3 }'); do git cat-file -p $blob > $blob.txt; done

更多细节请看这里 - https://medium.com/@CarrieGuss/how-to-recover-from-a-git-hard-reset-b830b5e3f60c#.6grpr3abr


1
以上的第一条命令是关键。一旦你运行了 git fsck --lost-found 一次,你就可以直接 cd .git/lost-found/other 来浏览那里的文件。失去的是文件的名称,但如果你通过检查内容来确定哪个文件是哪个,那么你就没问题了。 - torek
这是答案。但是我应该更清楚地表达:我只是想恢复我的文件结构等,而不是将这些 blob 转储回 txt。我手动完成了这个过程...并且非常小心...唉。 - Kevin
@Kevin - 在这种情况下,无法恢复文件结构。树/文件结构是提交,而它从未完成。 - manojlds

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接