我正在使用带有客户独立池的 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 [email protected]
;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 GHz(8 线程)+ 32 GB RAM、2xSSD 120 GB 软件 RAID1 + 2x HDD 3 TB 软件 RAID
答案1
增加:
pm.max_children = 20
pm.min_spare_servers = 2
pm.max_spare_servers = 4
request_terminate_timeout = 300s
request_slowlog_timeout = 300s
所有问题都消失了 ;)
答案2
我设法通过纠正日志上的文件权限来解决此问题。
确保运行 php-fpm 的用户可以读取和写入您配置的日志文件。
答案3
对我来说,MySQL 在达到默认的 150 max_connection 限制后会导致错误。在my.cnf
mysql8 中或上更改默认值,您可以在数据库运行时持续更新它。
-- mysql8
SET PERSIST max_connections = 1000;
SET @@PERSIST.max_connections = 1000;
当然,选择适合您的生产环境的连接数。
更改 FPM 设置对我来说不起作用。我甚至尝试在 FPM 中创建一个包含 5000 个工作程序的大型静态池。
在错误发生的同时捕获日志之后,我发现 MySQL 的使用达到了 max_connection 限制show process list;
。