AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 477786
Accepted
Spacedust
Spacedust
Asked: 2013-02-12 13:31:03 +0800 CST2013-02-12 13:31:03 +0800 CST 2013-02-12 13:31:03 +0800 CST

php-fpm 错误的文件描述符错误

  • 772

我正在使用带有客户独立池的 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 Software RAID1 + 2x HDD 3 TB Software RAID

php
  • 3 3 个回答
  • 16781 Views

3 个回答

  • Voted
  1. Best Answer
    Spacedust
    2013-02-13T03:41:29+08:002013-02-13T03:41:29+08:00

    增加:

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

    所有问题都消失了;)

    • 2
  2. Jaitsu
    2015-08-01T00:46:35+08:002015-08-01T00:46:35+08:00

    我设法通过更正日志的文件权限来解决这个问题。

    确保您配置的日志文件对于运行 php-fpm 的用户是可读和可写的。

    • 2
  3. Neal Bozeman
    2020-09-01T00:14:43+08:002020-09-01T00:14:43+08:00

    对我来说,MySQL 在达到默认的 150 max_connection 限制后导致了错误。更改my.cnfmysql8 中或上的默认值,您可以在数据库运行时持续更新它。

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

    当然,选择适合您的生产环境的连接数。

    对 FPM 设置的更改对我不起作用。我什至尝试在 5000 名工人的 FPM 中创建一个巨大的静态池。

    在错误发生的同时捕获日志后,我发现 MySQL 使用show process list;.

    • 0

相关问题

  • 用户特定的 Php.ini 当 php 作为模块运行时?

  • 使 php mail() 函数在 ubuntu-server 上工作的步骤是什么?

  • Web 服务器和数据库服务器位于完全不同的位置

  • PHP 作为 CGI 还是 Apache 模块?

  • 通过 VPN 连接什么是远程服务器 IP?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve