折雨的天空

博客介绍:本博客当前共有文章【968】篇,总阅读量【5,158,560】次,第一篇博客发表于【2011年04月06日 10时34分】,距今已【4978】天,感谢您的使用!

您的位置:折雨的天空 >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错误的调整

奖励一下

取消

分享不易,烦请有多多打赏,如您也困难,点击右边关闭即可!

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

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

-秒后自动关闭,如已打赏,或者不愿打赏,请点击右上角关闭图标。

发表评论

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