我正在运行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版本。显然,一些后台进程(在我的例子中是队列工作者)一直在进行,没有触发超时。这两个命令重置了它们,一切又恢复正常了。