';exec():无法派生';在Ubuntu 14.04.3 LTS上运行


'exec(): Unable to fork' on Ubuntu 14.04.3 LTS

我正在运行unittest脚本,对于测试用例设置,我需要不时运行shell命令。因此,shell命令在单元测试执行期间会运行大约50次。

它在CentOS 6.6版(Final)服务器上运行良好,但在Ubuntu 14.04.3 LTS上不起作用。

问题是,在大约第20次执行shell脚本后,我得到了以下错误:

exec(): Unable to fork [$(which mysql) -u user -ppwd test_db < "/opt/jenkins/workspace/some - project/application/../tests/Application/assets/sql/test_db.sql" 2> /dev/null]

我已经检查了互联网上的所有主题,但没有人帮助我。我增加了进程数量和打开文件的限制,以获得巨大的价值

# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 3885
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 100000
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 6553500
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

PHP报告了类似的数字。(文件test.php包含<?php echo system("ulimit -a");

# php test.php
time(seconds)        unlimited
file(blocks)         unlimited
data(kbytes)         unlimited
stack(kbytes)        8192
coredump(blocks)     0
memory(kbytes)       unlimited
locked memory(kbytes) 64
process              6553500
nofiles              100000
vmemory(kbytes)      unlimited
locks                unlimited
locks                unlimited

我以非root用户的身份从CLI运行脚本。

我已经将php内存大小增加到2Gb

memory_limit => 2048M => 2048M

我试过使用system、passthrough、shel_exec,但没有什么区别。

PHP版本为5.6

PHP 5.6.14-1+deb.sury.org~trusty+1 (cli) 

有人知道如何解决这个问题吗?

在我的案例中,问题非常简单,与我所做的配置更改无关。我认为将我的经验保留在这里是合理的,这样可以帮助其他开发人员避免同样的问题。

问题是服务器内存不足。这是一台1Gb RAM的虚拟机。当脚本内存使用量在700Mb左右时,它开始失败,并出现"无法分叉"错误。这很奇怪,听起来不像是记忆问题。

将服务器的内存大小增加到4Gb就解决了这个问题。

对于任何带着相同的exec(): Unable to fork问题(这是一个广泛的问题)来到这里的人来说,对我有效的是简单地运行:

service php7.0-fpm restart
service nginx restart

当然,将服务更改为您的PHP版本。显然,一些后台进程(在我的例子中是队列工作者)一直在进行,没有触发超时。这两个命令重置了它们,一切又恢复正常了。