nginx 出现504 Gateway Time-out的解决方法
本文介绍nginx出现504 Gateway Time-out问题的原因,分析问题并提供解决方法。 1.问题分析nginx访问出现504 Gateway Time-out,一般是由于程序执行时间过长导致响应超时,例如程序需要执行90秒,而nginx最大响应等待时间为30秒,这样就会出现超时。 ? 通常有以下几种情况导致 1.程序在处理大量数据,导致等待超时。 2.程序中调用外部请求,而外部请求响应超时。 3.连接数据库失败而没有停止,死循环重新连。 出现这种情况,我们可以先优化程序,缩短执行时间。另一方面,可以调大nginx超时限制的参数,使程序可以正常执行。 对于访问超时的设定,nginx与php都有相关的设置,可以逐一进行修改。 2.解决方法nginx配置 nginx.conf中,设置以下几个参数,增加超时时间 fastcgi_connect_timeout fastcgi连接超时时间,默认60秒 fastcgi_send_timeout nginx 进程向 fastcgi 进程发送请求过程的超时时间,默认值60秒 fastcgi_read_timeout fastcgi 进程向 nginx 进程发送输出过程的超时时间,默认值60秒 php配置 php.ini max_execution_time php脚本最大执行时间 ? php-fpm request_terminate_timeout 设置单个请求的超时时间 ? php程序中可加入set_time_limit(seconds)设置最长执行时间 例如 set_time_limit(0) 表示不超时。 。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 是什么导致nginx服务器上的此错误 – 502错误的
- web-server – 更新后nginx不会重启;配置测试失
- utf-8-使用pcre 8.3在nginx上的unicode url重写规
- linux – nginx:[emerg]未知指令“”在/etc/n
- Nginx:1M map的最佳map_hash_max_size和map_has
- nginx – 减少Gitlab内存占用
- nginx – 如何创建这种类型的子域:example.tes
- nginx比apache处理静态文件速度快,但是nginx处理
- Nginx#ngx_http_limit_req_module:超过费率后50
- linux – Nginx,从某些域引用日志引用到单独的