php CURL请求502

增加 pm.max_children 的值
  • 当前值为 50,如果并发请求较多,可能会耗尽子进程资源,导致 502。
  • 增加到 100 或更高(根据服务器内存和负载能力调整)。
2. 调整 request_terminate_timeout
  • 当前为 100 秒,适合大多数脚本。如果你的应用程序中某些脚本执行时间较长,可以进一步增加到 300 或更高。
3. 增加 listen.backlog
  • 当前值为 8192,通常已经足够高。如果并发流量特别大,可以再增加,例如 16384
4. 检查 pm 模式
  • 你的 pm 模式为 dynamic,适合多数情况。如果流量非常稳定,且波动不大,可以尝试改为 static 模式,设置一个固定数量的子进程(例如 pm.max_children = 100)。
5. 检查 listen 的权限
  • 当前 listen.mode = 0666,确保 Nginx 有权限访问 /tmp/php-cgi-74.sock

  • 如果有权限问题,修改为以下内容:

    复制代码

    listen.owner = www listen.group = www listen.mode = 0660

6. 优化日志配置
  • 检查 slowlog 是否有效,确保记录慢请求的日志,便于后续排查:

    request_slowlog_timeout = 10 slowlog = /www/server/php/74/var/log/slow.log

7. 增加 rlimit_filesrlimit_core
  • 允许更多文件描述符:

    复制代码

    rlimit_files = 65535 rlimit_core = 0

优化后的配置示例

复制代码
[global]
pid = /www/server/php/74/var/run/php-fpm.pid
error_log = /www/server/php/74/var/log/php-fpm.log
log_level = notice

[www]
listen = /tmp/php-cgi-74.sock
listen.backlog = 16384
listen.allowed_clients = 127.0.0.1
listen.owner = www
listen.group = www
listen.mode = 0660
user = www
group = www

pm = dynamic
pm.max_children = 100        ; 增加最大子进程数量
pm.start_servers = 10        ; 启动时的进程数
pm.min_spare_servers = 10    ; 保持的最小空闲进程数
pm.max_spare_servers = 30    ; 保持的最大空闲进程数

pm.status_path = /phpfpm_74_status

request_terminate_timeout = 300
request_slowlog_timeout = 10
slowlog = /www/server/php/74/var/log/slow.log

rlimit_files = 65535
rlimit_core = 0
复制代码

检查和排查步骤

1. 重启 PHP-FPM 和 Nginx

每次修改配置后重启服务:

复制代码

service php-fpm-74 restart service nginx restart

2. 检查日志
  • PHP-FPM 错误日志

    tail -f /www/server/php/74/var/log/php-fpm.log

  • Nginx 错误日志

    tail -f /var/log/nginx/error.log

  • 慢请求日志 : 如果启用了 slowlog,分析慢请求的脚本,优化这些脚本。

3. 测试并发

使用工具如 abwrk 模拟并发请求,测试是否可以正常响应:

ab -n 1000 -c 50 http://your-domain.com/

4. 系统资源监控

监控服务器的内存、CPU 和磁盘 I/O 使用情况,确认是否资源耗尽:

htop free -h

相关推荐
JaguarJack10 小时前
FrankenPHP 原生支持 Windows 了
后端·php·服务端
BingoGo11 小时前
FrankenPHP 原生支持 Windows 了
后端·php
JaguarJack1 天前
PHP 的异步编程 该怎么选择
后端·php·服务端
BingoGo1 天前
PHP 的异步编程 该怎么选择
后端·php
JaguarJack2 天前
为什么 PHP 闭包要加 static?
后端·php·服务端
ServBay3 天前
垃圾堆里编码?真的不要怪 PHP 不行
后端·php
用户962377954483 天前
CTF 伪协议
php
BingoGo5 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php
JaguarJack5 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php·服务端
BingoGo6 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php