原因:某些htpp请求服务端处理太慢,影响了其他http请求。
1.配置php.ini的`max_execution_time`和`max_input_time`。但是改后还是报了不少的499。
(set_time_limit()函数和配置指令max_execution_time只影响脚本本身执行的时间。任何发生在诸如使用system()的系统调用,流操作,数据库操作等的脚本执行的最大时间不包括其中,当该脚本已运行。在测量时间是实值的Windows中,情况就不是如此了。)
2.到`php-fpm.conf`里面设置为`request_terminate_timeout = 10`,很少报499,但是偶尔还会出现。`request_terminate_timeout`会杀掉进程,导致偶尔出现502http状态码。
3.`根本原因`是php提供的进程太少,处理不过来,应该多加进程。
原来的配置是:
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3
改为:(可以根据情况调得更大)
pm.max_children = 20
pm.start_servers = 10
pm.min_spare_servers = 10
pm.max_spare_servers = 20
4.结合php慢日志(slowlog)来找出执行慢的脚本,并优化之。
设置:
request_slowlog_timeout = 5
slowlog = /data/logs/php-fpm-slowlog.log
本文探讨了PHP请求超时问题,通过调整php.ini和php-fpm.conf中的参数,如max_execution_time、request_terminate_timeout,解决499和502问题。重点在于增加pm.max_children配置以提升并发处理能力,并利用slowlog追踪执行慢的脚本。
3万+

被折叠的 条评论
为什么被折叠?



