1.首先要明确504错误是nginx配置问题,所以调试php等其他配置是木有用的.这样目标已经缩小很多了.

2.其次, 明确这个nginx是做什么, 一般有两种:

a. 只是将请求代理转发, 在配置我们能看到proxy\_pass ip 字眼

b. 将请求通过fastcgi转发给php-fpm, 在配置有fastcgi\_pass ip:port 字眼


3. 最后,对于以上不同的分类对症配置:

两种都是在nginx配置文件中的 http块下增加如下:

a情况加上 : proxy\_read\_timeout 3600s;

b情况加上: fastcgi\_read\_timeout 3600s;

其实很多网上说a情况还要再加上 proxy\_connect\_timeout 3600s; proxy\_send\_timeout 3600s;配置

b情况要再加上fastcgi\_connect\_timeout 3600s; fastcgi\_read\_timeout 3600s; 配置

但是实质上最关键的是read\_timeout参数, 其他两个一般是不怎么会超时, 可配可不配.

note: 有些情况一条请求链路上可能有多层nginx, 所以必定会a,b两种情况都存在的情况,具体哪个nginx是哪种情况,对应的nginx配置认证看下就知道了.

做了如上配置后,nginx504错误是可以解决的, 但如果在以上问题解决完后,xdebug出现过了一段时间就会自动断开并跳出调试的问题.因为是nginx+php-fpm模式, 那么这个问题只能是php的问题.这个是php的脚本执行超时限制. 如果你用的fpm模式, 那么只要修改php-fpm的配置, 找到其中request\_terminate\_timeout字段设置一个较大的值, 或者设置为0表示永不超时,fpm的默认值就是永不超时.然后重启你pph-fpm以便生效修改的配置.

标签: nginx, php, 配置, xdebug, timeout, 调试, fpm

相关文章推荐

添加新评论,含*的栏目为必填