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

php-fpm Ошибки неверного дескриптора файла

Я использую php-fpm с отдельными пулами клиентов.

Иногда страница зависает, затем отображается внутренняя ошибка сервера 500, и я получаю такие ошибки в журнале ошибок:

[11-Feb-2013 22:12:39] ERROR: unable to read what child say: Bad file descriptor (9)
[11-Feb-2013 22:12:39] ERROR: unable to read what child say: Bad file descriptor (9)
[11-Feb-2013 22:12:42] WARNING: [pool oferty] child 31186 exited on signal 11 (SIGSEGV) after 198.250454 seconds from start

Мои текущие настройки:

    [admin]
listen = 127.0.0.1:51006
listen.backlog = -1
listen.allowed_clients = 127.0.0.1
user = admin
group = admin
pm = dynamic
pm.max_children = 10
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 2
pm.max_requests = 1000
;pm.status_path = /status
;ping.path = /ping
;ping.response = pong
request_terminate_timeout = 180s
request_slowlog_timeout = 180s
slowlog = /var/log/php-fpm/slow.log
rlimit_files = 1024
rlimit_core = 0
;chroot =
;chdir = /var/www
catch_workers_output = yes
security.limit_extensions = .php .php3 .php4 .php5

env[HOSTNAME] = $HOSTNAME
env[PATH] = /usr/local/bin:/usr/bin:/bin
env[TMP] = /tmp
env[TMPDIR] = /tmp
env[TEMP] = /tmp

;php_admin_value[sendmail_path] = /usr/sbin/sendmail -t -i -f webmaster@domain.com
;php_flag[display_errors] = off
php_admin_value[error_log] = /var/log/php-fpm/error.log
php_admin_value[session.save_path] = /var/lib/php/session
php_admin_flag[log_errors] = on
php_admin_value[memory_limit] = 128M

Что нужно увеличить? Мой сервер использует Intel Core i7 2600 3,4 ГГц (8 потоков) + 32 ГБ ОЗУ, 2xSSD 120 ГБ, программный RAID1 + 2x HDD 3 ТБ, программный RAID

Мне удалось исправить эту проблему, исправив права доступа к файлам в журналах.

Убедитесь, что ваши настроенные файлы журналов доступны для чтения и записи пользователю, запускающему php-fpm.

Вырос:

pm.max_children = 20
pm.min_spare_servers = 2
pm.max_spare_servers = 4
request_terminate_timeout = 300s
request_slowlog_timeout = 300s

и все проблемы ушли;)

Для меня MySQL вызывал ошибку после достижения предела max_connection по умолчанию 150. Измените значение по умолчанию в my.cnf или на mysql8 вы можете постоянно обновлять его при работающей БД.

-- mysql8
SET PERSIST max_connections = 1000;
SET @@PERSIST.max_connections = 1000;

Конечно, выберите количество подключений, подходящее для вашей производственной среды.

Изменения в настройках FPM у меня не работали. Я даже пробовал создать массивный статический пул в FPM из 5000 воркеров.

После захвата журналов в то же время, когда возникла ошибка, я обнаружил, что MySQL находится на пределе max_connection, используя show process list;.