Ubuntu Linux git gc说错误:无法运行重新包装

Jav*_*Dev 5 linux git ubuntu posix signals

我正在阅读其他类似标题的帖子,但似乎与我无关.我在我当地的ubuntu盒子里有一个git repo.我的文件是mysql dump我分成2mb文件.当我git gc时,这是输出:

git@pc:~/repos/x$ git gc
Counting objects: 17244, done.
Delta compression using up to 4 threads.
Killedssing objects:  90% (2491/2767)   
error: failed to run repack
Run Code Online (Sandbox Code Playgroud)

有没有办法追踪造成的?我已经试过了

git config --global pack.windowMemory "20m"
git config --global pack.packSizeLimit "20m"
git config --global pack.threads "1"
Run Code Online (Sandbox Code Playgroud)

但这是输出

git@pc:~/repos/x$ git gc
Counting objects: 17244, done.
Killedssing objects:   3% (88/2767)   
error: failed to run repack
Run Code Online (Sandbox Code Playgroud)

编辑

这对我有用:

git config --global pack.windowMemory "20m"
git config --global pack.packSizeLimit "20m"
git config --global pack.threads "4"
git config --global pack.window "2"
git config --global pack.depth "10"
Run Code Online (Sandbox Code Playgroud)

看起来因为我只有256 ram vps.和其他过程已经吃100mb.我也会尝试升级我的vps,因为这个配置使得git gc和git clone非常慢.

再次编辑 经过更多调查,这是因为线程.我有4个虚拟核分配给我的vps,当我把pack.threads"2"没有其他时,问题就消失了.

我让我的提供者给我更多的ram,但这没有帮助.只有在我配置线程时.希望这能帮到别人

Tod*_*obs 3

从您的输出来看,该进程似乎在增量压缩阶段被外部进程(例如 Linux OOM Killer或其他一些资源管理进程)终止。如果您的内存或磁盘空间不足,那么这将为您提供一个开始调查的合理位置。

您还可以考虑在strace下运行您的进程。这通常会告诉您程序收到信号时正在做什么,但可能并不总能告诉您信号发送者实际上是谁。

如果 strace 失败,Git 源当前有 12 个对sigaction(2)的引用,您可以利用这些引用通过检查siginfo_t struct来确定信号发送者。这很可能需要核心转储或交互式调试器(例如gdb )