折雨的天空
nginx php超时导致502错误的调整
2019-11-25 我好笨
需要改一下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

发表评论:
昵称

邮件地址 (选填)

个人主页 (选填)

内容