Назад | Перейти на главную страницу

Ошибка скрипта PHP «exec (): невозможно выполнить форк…» в Ubuntu 14.04.3 LTS

Я запускаю скрипты unittest, и для настройки тестового примера мне нужно время от времени запускать команду оболочки. В результате команда оболочки запускается примерно 50 раз во время выполнения unittest.

Он работает нормально на сервере CentOS версии 6.6 (Final), но не работает в Ubuntu 14.04.3 LTS.

Проблема в том, что примерно после 20-го выполнения сценария оболочки я получаю следующую ошибку:

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 из интерфейса командной строки.

Я увеличил размер памяти php до 2 ГБ

memory_limit => 2048M => 2048M

Я пробовал использовать system, passthrough, shel_exec, и это не имеет значения.

Версия PHP 5.6

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

Кто-нибудь знает, как решить проблему?

Вы используете apache / nginx с php или php из оболочки?

В любом случае проблема может заключаться в утечке процесса или использовании слишком большого количества памяти.

Вы можете оставить корневую оболочку для сервера открытой и попытаться воспроизвести эту проблему из другой оболочки (или браузера).

Затем, когда это произойдет снова, посмотрите на дерево процессов ecc из корневой оболочки и сообщите нам