当前位置: 首页 > 面试题库 >

Nginx + PHP-FPM 7.1-504网关超时

丌官皓君
2023-03-14
问题内容

我在synology nas上将nginx 1.12和php-fpm 7.1作为单独的docker容器运行,并且如果php-
script运行时间超过60s,则会收到504 Gateway错误。我已经尝试了几个nginx配置参数,但是错误仍然存​​在。

这是我实际的nginx配置:

#user  www-data;
#group http
worker_processes  1;

error_log  /opt/data/logs/nginx_error.log notice;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    #keepalive_timeout 30s;
    sendfile on;
    #tcp_nopush off;
    tcp_nodelay on;

    #gzip  off;

    send_timeout 300

    server {
        listen       80;
        server_name  "";

        root   /opt/php;
        index  index.php;

        location /data/ {
           sendfile        on;
           root   /opt;
        }

        location ~ \.php$ {

            include fastcgi_params;

            fastcgi_split_path_info ^(.+?\.php)(/.*)$;
            if (!-f $document_root$fastcgi_script_name) {
                return 404;
            }

            # Mitigate https://httpoxy.org/ vulnerabilities
            fastcgi_param HTTP_PROXY "";

            fastcgi_pass   php:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            fastcgi_read_timeout 300;
            #fastcgi_buffering off;
            #fastcgi_keep_conn on;
            #fastcgi_intercept_errors on;
            #fastcgi_cache  off;
            #fastcgi_ignore_client_abort on;

        }

        location ~ ^/(status|ping)$ {
             access_log off;
             include fastcgi_params;
             fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
             fastcgi_pass php:9000;
         }
    }

}

php-testscript:

<?php 
sleep(65);
echo "done!";
file_put_contents("/opt/data/timetest.txt", "\nEnd", FILE_APPEND);

60秒后,浏览器显示504网关超时。php脚本仍在运行,并且还在将文本写入文件

Nginx错误日志:

2017/07/22 08:16:32 [error] 8#8: *10 upstream timed out (110: Connection timed out) while reading response header from upstream, client: 172.17.0.1, server: , request: "GET /timetest.php HTTP/1.1", upstream: "fastcgi://172.17.0.3:9000", host: "192.168.0.100:8081"

有人知道吗?


问题答案:

问题可能是为什么您的后端需要这么长时间才能做出响应?不确定您的用例,但通常等待很长一段时间才能获得响应并不友好。

回答您的问题:

我找到了此链接:https : //easyengine.io/tutorials/php/increase-script-execution-
time/

添加在/etc/php5/fpm/php.ini中

max_execution_time = 300

在/etc/php5/fpm/pool.d/www.conf中设置

request_terminate_timeout = 300

在/etc/nginx/nginx.conf中设置

http {
 #...
 fastcgi_read_timeout 300;  
 #...
}

并在您的配置中:

location ~ \.php$ {
 include /etc/nginx/fastcgi_params;
 fastcgi_pass unix:/var/run/php5-fpm.sock;
 fastcgi_read_timeout 300;
}

并重装服务

service php5-fpm reload
service nginx reload


 类似资料:
  • 我有一个PHP Android推送通知脚本。当我运行脚本时,我在浏览器中得到以下响应“504网关超时nginx”。在常规日志概述中的服务器上,我收到以下错误: 错误: 504,消息: GET/gcm_test.phpHTTP/1.1,来源: nginx SSL访问 在我的服务器上的代理错误日志中,我收到以下错误: 2016/07/25 08:18:19[错误]23882#0:*4375从上游读取响

  • 我正在尝试使用Nginx在Ubuntu16.4服务器上托管Django1.11应用程序。但是在运行服务器之后,我得到了 *1从上游读取响应标头时上游超时(110:连接超时),客户端:118.179.95.25,服务器:18.136.204.142,REQU$ 2019/07/24 18:13:13[错误]15221#15221:*1从上游读取响应标头时上游超时(110:连接超时),客户端:118.

  • 我使用PHP和Apache以及nginx作为反向代理,所有这些都在Docker上,我有几个长时间运行的调用在60秒后计时,导致504网关超时。我知道我的应用程序被成功调用,因为我正在跟踪我的PHP应用程序的日志,我可以看到它正在积极地向日志写入。每次都是60秒的超时,但我似乎不知道那个设置在哪里。 我尝试了这篇文章中的建议,但没有任何效果。我已经用一些与时间相关的设置更新了php.ini文件,并验

  • 我有一台工作的服务器,上面有nginx。服务器(专用)仅用于托管drupal站点。 最近,我们决定在它上面也举办一个magento商店,并开始准备。由于magento和nginx不能一起工作,我们不得不将nginx升级到最新版本。一切似乎都很顺利。 昨天我已经安装了php5-curl(由magento重新定义)和…事情变糟了。(尽管在curl.ini中注释出一行并不能解决任何问题) 访问php站点

  • 本地开发环境php+nginx出现504超时? 环境:thinkphp6, php7.3,nginx1.15 放大: nginx的请求超时和加载超时

  • 我在一个Spring boot项目中工作,有一个请求返回网关超时504。我可以增加这个超时吗?这是一个属性,我可以改变在独立的完整。xml?我使用的是wildfly服务器。 请求在1分钟内触发两次,每次触发时间为1分钟。