当我们在git提交的时候,发现推不上去,出现:
pony.shi@rmsh19:~/work/8350_418/frameworks/base$ git push shgit HEAD:refs/for/sm8350_s_haydn_rebase_ssi_20220305
Counting objects: 2312, done.
Delta compression using up to 56 threads.
Compressing objects: 100% (1830/1830), done.
Writing objects: 100% (2312/2312), 2.51 MiB | 14.38 MiB/s, done.
Total 2312 (delta 1173), reused 1176 (delta 100)
remote: Resolving deltas: 100% (1173/1173)
remote: Counting objects: 191680, done
fatal: Unpack error, check server log
error: remote unpack failed: error Missing blob 09068005b90f9ecbfe86bda317114ed079971a94
To ssh://gerrit.blackshark.com:29418/git/android/platform/frameworks/base
! [remote rejected] HEAD -> refs/for/sm8350_s_haydn_rebase_ssi_20220305 (n/a (unpacker error))
error: failed to push some refs to 'ssh://gerrit.blackshark.com:29418/git/android/platform/frameworks/base'
解决方案看如下:
我们可以在提交时加上 --no-thin 参数来解决这个问题,也就是说使用下方这样的命令来进行提交就可以了:
git push --no-thin review HEAD:refs/for/xxxx
这个参数的含义是“在向服务器提交代码时不对信息进行压缩处理”,执行命令 git push --help 可以查看到说明信息:
--[no-]thin
These options are passed to git-send-pack(1). A thin
transfer significantly reduces the amount of sent data when
the sender and receiver share many of the same objects in
common. The default is --thin.
【问题原因】
具体失败的原因应该从 Gerrit 服务器的 log 中进行分析,我没有去查看 log(好像我也没有权限),但根据其他同行的分析,这个问题可能是“Gerrit 与 git 不兼容导致的。具体原因是 git 提交时,在 Gerrit 生成了一个未关闭的 review 请求,但是这个请求并不属于任何一个提交”。
【参考资料】
1.git flow 与 gerrit