欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

如何解决“504 Gateway Time-out”错误

做网站的同学经常会发现一些nginx服务器访问时候提示504 Gateway Time-out错误,一般情况下是由nginx默认的fastcgi进程响应慢引起的,但也有其他情况,这里我总结了一些解决办法供大家参考。
如何解决“504 Gateway Time-out”错误
 

方法/步骤

 
  1. 1

    情况一:由于nginx默认的fastcgi进程响应缓冲区太小造成

           这种情况下导致fastcgi进程被挂起,如果fastcgi服务队这个挂起处理不是很好的话,就可能提示“504 Gateway Time-out”错误。

  2. 2

    情况一解决办法:

           默认的fastcgi进程响应的缓冲区是8K,我们可以设置大一点,在nginx.conf里,加入:fastcgi_buffers 8 128k

           这表示设置fastcgi缓冲区为8块128k大小的空间。

  3. 3

    情况一解决办法(改进):

           在上述方法修改后,如果还是出现问题,我们可以继续修改nginx的超时参数,将参数调大一点,如设置为60秒:

           send_timeout 60;

           经过这两个参数的调整,结果没有再提示“504 Gateway Time-out”错误,说明效果还是挺不错的,问题基本解决。

  4. 4

    情况二:PHP环境的配置问题

           这里我们需要对php-fpm和nginx进行配置修改。因为这种情况下,也会出现“504 Gateway Time-out”错误提示。

  5. 5

    情况二解决办法( php-fpm配置修改):

          将max_children由之前的10改为30,这样操作是为了保证有充足的php-cgi进程可以被使用。

          将request_terminate_timeout由之前的0秒改成60秒,这样使php-cgi进程处理脚本的超时时间提高到60秒,可以防止进程被挂起以提高利用效率。

  6. 6

    情况二解决办法(nginx配置修改):

          为了减少fastcgi的请求次数,尽量维持buffers不变,我们要更改nginx的几个配置项,如下:

          将fastcgi_buffers由4 64k改为2 256k;

          将fastcgi_buffer_size 由64k改为128k;

          将fastcgi_busy_buffers_size由128k改为256k;

          将fastcgi_temp_file_write_size由128k改成256k。

  7. 7

    情况二解决办法修改完,我们需要重新加载php-fpm和nginx的配置,然后再进行测试。之后就没有发现“504 Gateway Time-out”错误,效果也还是不错的!

    END

注意事项

 
  • 本经验为原创,百度经验首发,转载请注明。

来自  http://jingyan.baidu.com/article/6fb756ecbf4774241858fb9a.html


WDCP LNMPA和LNMP 504 Gateway time-out错误的解决方法

标签: linux wdcp
 1836人阅读 评论(2) 收藏 举报
 分类:
 
Nginx的特点是处理静态很给力,Apache的特点是处理动态很稳定,两者结合起来便是LNMPA,nginx处理前端,apache处理后端,这样处理静态会很快,处理动态会很稳定。当我以为安装完成以后便万事大吉,不料更新网站的时候却出现504 Gateway time-out;起初还以为这是偶然,多次尝试后依然出现这样的情况,因此才决定查找解决方法。
 
  LNMP面对504 Gateway time-out
 
  因为504 Gateway time-out是Nginx的专属错误,因此起初我以为是nginx配置出错,查找网上的教程,找到相应的解决方法,下面简单说说LNMP面对此种情况的解决方案。Nginx出现这样的错误,是因为对PHP-CGI进程数限制得太小,面对更新网站这类操作,很可能出现进程不足而超时的情况,因此要修改两处涉及到处理时间的文件。
 
  首先是nginx.conf文件,这个文件在/www/wdlinux/nginx/conf/nginx.conf,打开以后,主要修改前面几个时间,建议修改为120秒以上。至于用什么工具修改,推荐在线命令行编辑;或者用winscp下载下来,用Dreamweaver修改。
 
/www/wdlinux/nginx/conf/nginx.conf 和 /www/wdlinux/nginx-1.0.15/conf/nginx.conf是一样的。
  fastcgi_connect_timeout 300s;
 
  fastcgi_send_timeout 300s;
 
  fastcgi_read_timeout 300s;
 
  fastcgi_buffer_size 128k;
 
  fastcgi_buffers 8 128k;#8 128
 
  fastcgi_busy_buffers_size 256k;
 
  fastcgi_temp_file_write_size 256k;
 
  其次要修改php-fpm.conf文件,这个文件在/www/wdlinux/etc/php-fpm.conf,不同的一键安装包位置有所不同,反正找找php安装以后文件下面的etc文件夹即可,在线编辑或下载下来用Dreamweaver编辑。
 
  进入文件后搜索”max_children”这是php-cgi进程数,一个进程占20M~30M内存,按自己的VPS或云主机内存进行计算,好比512M内存,推荐设置为18即可;另外搜索”request_terminate_timeout”,这是超时时间,若php程序要长时间运作,那么设置时间大一点会比较好,好比设置为120秒,单位默认是秒,或者写成120同样可以。
 
  LNMPA遇到504 Gateway time-out
 
  当我按照Nginx的解决方法设置,很快设置成功,不过依然会出现504 Gateway time-out,这时我直接切换为LNMP组合,发现不再遇到504 Gateway time-out错误,这说明设置已经生效;为什么还会出现这样的错误呢?
 
  经过大量的资料查找,终于发现这是Nginx与Apache通信时间设置问题,当用户发出php脚本执行请求,nginx不会执行php,会把这个问题留给后台的apache,nginx会等待一段时间,apache可以在等待时间内处理php脚本请求,若未处理完,nginx便已未收到数据请求而返回504 Gateway time-out错误,实际情况是apache依然会在后台处理完php脚本,只是前台返回错误。
 
  解决方法是修改nginx与apche通信时间,具体是配置naproxy.conf,这个文件在/www/wdlinux/nginx/conf/下面,名字可能会有变化,好比有的安装包是naproxy.conf,反正是**proxy.conf文件。
 
  proxy_connect_timeout 60;
 
  proxy_send_timeout 600;
 
  proxy_read_timeout 90;
 
  proxy_buffer_size 128k;
 
  proxy_buffers 8 128k;
 
  proxy_busy_buffers_size 256k;
 
  proxy_temp_file_write_size 100m;
 
  第一项是连接时间,前端连接后端时间,60s以内即可,第二个是发送时间,允许后端返回数据的时间,90s以内即可,第三个时间是读写时间,这是前端等待后端处理时间,这是导致504 Gateway time-out的根本原因,出现这个错误,说明这个值太小,推荐不小于600s,服务器越差,那么设置得更长,保证处理完毕。
 
  当我把这个文件设置好,重启nginx和apache,再次更新文章,已经不会遇到这类错误,说明出错原因不是nginx,而是前段和后端的通信时间太短。另外,nginx还会有502错误,实际上原理是差不多的,同样设置上面这部分文件,LNMPA组合依然是设置前后端的通信时间。

来自 http://blog.csdn.net/zhangzhikaixinya/article/details/46913733
普通分类: