折雨的天空

新浪微薄腾讯微薄

最新碎语:最近霉到了住。哎。。。

您的位置:折雨的天空 >php开发> nginx php超时导致502错误的调整

nginx php超时导致502错误的调整

需要改一下php.ini 里面的 max_execution_time 的值 和 php-fpm.conf 中的 request_terminate_out 的值就可以了。这两项都是用来配置PHP最大执行时间,超时时php-fpm会终止脚本的执行,同时还会终止执行脚本的Worker进程。就像在日志中所看到的样,php-fpm child 18523 被终止后重新生成了新的worker进程18581,所以 nginx 发现与自己通信的连接断了,就自然会返回502错误给客户端。

为了方便测试,和上边 nginx 配置项里的 keepalive_timeout 的值一样,都设置成10分钟。

php.ini :

max_execution_time = 600

php-fpm.conf:


request_terminate_timeout = 600


nginx 进程 和 php-fpm 进程通信一般是采用套接字(ip:port)的方式。产生504错误的原因是 nginx 转发给 fastcgi 的请求没有在限制时间(默认60s)内的到响应。
需要在 nginx将php请求转发给fastCGI 的location里(或fastcgi.conf里) 配置 和 fastCGI 通信的超时时长,为了方便测试,仍设置为 10 分钟

fastcgi_connect_timeout 600;
fastcgi_read_timeout 600;
fastcgi_send_timeout 600;


location ~ \.php$ {
 
    root html;
 
    fastcgi_pass 127.0.0.1:9000;
 
    fastcgi_index index.php;
 
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 
    fastcgi_connect_timeout 600;
 
    fastcgi_read_timeout 600;
 
    fastcgi_send_timeout 600;
 
    include fastcgi_params;
 
}


原文:https://blog.csdn.net/Asce_zz/article/details/89384978

------------正 文 已 结 束, 感 谢 您 的 阅 读 (折雨的天空)--------------------

转载请注明本文标题和链接:《nginx php超时导致502错误的调整

奖励一下

取消

您的认可,是我写博客的动力,谢谢您!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

发表评论

路人甲 表情
看不清楚?点图切换