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

相关推荐
终极定律25 分钟前
qt:输入控件操作
开发语言·qt
JenKinJia40 分钟前
Windows10配置C++版本的Kafka,并进行发布和订阅测试
开发语言·c++
煤炭里de黑猫42 分钟前
Lua C API :lua_insert 函数详解
开发语言·lua
笨鸟笃行44 分钟前
爬虫第七篇数据爬取及解析
开发语言·爬虫·python
编程乐趣1 小时前
一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略来了!
开发语言·c#
java1234_小锋1 小时前
一周学会Flask3 Python Web开发-response响应格式
开发语言·python·flask·flask3
Jelena157795857921 小时前
使用Java爬虫获取1688 item_get_company 接口的公司档案信息
java·开发语言·爬虫
java1234_小锋1 小时前
一周学会Flask3 Python Web开发-flask3模块化blueprint配置
开发语言·python·flask·flask3
我是苏苏1 小时前
C#基础:使用Linq进行简单去重处理(DinstinctBy/反射)
开发语言·c#·linq
小小码农(找工作版)1 小时前
C#前端开发面试题
开发语言·c#