36

我们将 Gerrit 用于我们的 Git 存储库。在一个已经活跃了几个月的项目上,我们突然无法推动任何更改。当我们执行时,git push我们会看到以下错误:

error: unpack failed: error Missing tree 14d62f0ed4385e3f68f226ac133fa9932a9c65c9

执行git fsck --full收益率:

dangling tree 2701c92fb6eab1826482f6bcc9598413e651a92a  
dangling blob c505b3b12cfacd1e26dec8dc559820a30fc20c27  
dangling blob 8907f94b5b4ec881e1b86d50681795e368c167ff  
dangling blob 4938d9fc34c6e2f92c68872bfec6e070b2b3a9c2  
dangling blob 8a5c8b8d35484ea1470e2d8e6c482fcb97b23d0f  
dangling commit 3072d3314e20bf6c6998e1c02986d83019d3e1df  
dangling tree 5377d7f7111d340854c3ee0946667c202227e603  
dangling tree c3783e9ab540457924ceb9f9fb5ea1c2b97472b1  
dangling blob 8b92d1765038e4ec5e721f98a2aabb305a7f9819  
dangling tree 38a03153f0f18ca15846e9bd4983a86800a43a94  
dangling commit 8db2d6ae5364174bebe13720a359ddb2e62d4c9d  

我们所有的开发人员在尝试推送时都遇到了同样的错误。到目前为止,我们已经尝试重新初始化 gerrit repo (git init --bare ...) 并推动它。我们还尝试使用单独的 repo 创建一个新的 gerrit 项目。最后,我们不断收到同样的错误。

有没有人知道原因是什么,或者如何恢复?

4

14 回答 14

48

使用git push --no-thin而不是git push.

来自 Git 文档:

当发送者和接收者共享许多相同的对象时,精简传输会显着减少发送的数据量。默认值为--thin。

于 2015-09-23T14:54:18.467 回答
20

我在我的 tortiuse git 上遇到了同样的错误。我终于得到了这个错误的根本原因。

导致此错误的步骤;

  • 在头部创建一个新分支。
  • 对新分支进行一些修改
  • 有人还对 head 分支进行了修改
  • 尝试推动你的分支

如果创建本地分支并且直到在头分支中进行一些修改才推送,则会发生此错误。这是正常的事情,因为远程头分支在推送操作之前对本地分支一无所知。

为了解决这个错误,切换头分支得到一个完整的拉动作。然后切换您的分支并尝试推送。

于 2015-07-08T06:58:24.813 回答
9

备份它……在你尝试任何事情之前,立即备份它。

现在,这听起来很不幸。听起来您没有定期备份可以访问,这也很遗憾。不过,有一个好消息:我敢打赌你的开发人员有这个文件,虽然它可能在一个包文件中。在其他人的 .git 目录中尝试以下操作。请注意,git 使用哈希的前两个字符作为目录名称。

find . -name d62f0ed4385e3f68f226ac133fa9932a9c65c9

如果出现这种情况,将该文件复制到服务器上的相同相对路径,生活应该会顺利进行。如果没有,那么试试这个:

find . -name \*.idx -exec cat {} \; | git show-index | grep 14d62f0ed4385e3f68f226ac133fa9932a9c65c9

这不会告诉你它是哪个包文件(你可以快速编写脚本或手动执行),但它会告诉你它在那里。找到正确的包文件并展开它...

git unpack-objects $FILE

从那里,将文件复制到服务器上的相同相对路径。如果这不能解决问题,则需要进一步的工作。交换开发人员的最新存储库可能会解决问题。您可能还想探索https://git.wiki.kernel.org/index.php/GitFaq#How_to_fix_a_broken_repository.3F,或发布更新评论并等待我回到这个问题。

于 2011-08-29T22:52:36.540 回答
9

我有同样的问题。为了解决这个问题,我使用了 git fetch 然后我再次推送,它工作得很好。

于 2018-06-28T15:31:13.270 回答
7

当我们得到这个时,我几乎总是可以用 git gc 来修复它:

git gc --aggressive --prune=now

首先备份你的 git 仓库!

于 2017-06-29T20:46:51.743 回答
4

尝试一个git pull --rebase.

我保存了差异(git show > ~/mychanges.txt,取出文件顶部的提交消息)。签出的新分支 ( git checkout -b newbranch) 应用了更改 ( git apply ~/mychanges.txt),然后执行了git pull --rebase. 然后一切正常。

于 2013-05-22T15:17:56.433 回答
3

如果不在 master 分支上,您可以通过以下方式简单地删除远程分支:

git push --delete origin <branch_name>

然后将您的分支推回远程:

git push -u origin <branch_name>
于 2015-03-01T05:03:36.107 回答
1

这通常发生在提交和推送的时间不同并且最终导致两棵树之间不匹配的情况下。给定上游的远程分支和本地分支foo

首先使用丢弃所有未提交的更改

git reset --hard foo

然后使用跟踪远程分支

git branch --set-upstream-to=upstream/foo

最后

git pull
于 2017-12-08T13:35:45.460 回答
1

先尝试做

混帐 gc

然后做

git 推送

遇到同样的问题。上述解决方案对我有用。

于 2020-09-24T06:58:36.070 回答
0

从技术上讲,这个答案有点晚了,但对我有用的是为我试图推送的变更集创建一个补丁,将存储库重新克隆到另一个磁盘位置,应用补丁,重新提交并推送。

于 2014-07-10T13:01:09.747 回答
0

快速解决方案是 Fetch -> Rebase-> Commit 然后推送。

于 2015-02-25T11:50:27.090 回答
0

就我而言,事实证明我在 git rebase -i origin/master 之前忘记了 git fetch。因此,当我尝试推送到 gerrit 时,我收到了上述错误。

于 2019-07-17T19:54:25.760 回答
0

奇怪的是,这个--no-thin论点对我不起作用。起作用的是git pull(很可能是git fetch.

于 2020-01-24T22:05:35.907 回答
0

我删除了我的主分支并再次创建。它的工作。git branch -D master, git checkout master 幸运的是它工作

于 2019-05-31T10:21:58.413 回答