当前位置: 首页 > 知识库问答 >
问题:

Nginx提供的PHP-FPM:504网关超时-Nginx

谈禄
2023-03-14

我有一个PHP Android推送通知脚本。当我运行脚本时,我在浏览器中得到以下响应“504网关超时nginx”。在常规日志概述中的服务器上,我收到以下错误:

错误: 504,消息: GET/gcm_test.phpHTTP/1.1,来源: nginx SSL访问

在我的服务器上的代理错误日志中,我收到以下错误:

2016/07/25 08:18:19[错误]23882#0:*4375从上游读取响应标头时上游超时(110:连接超时),客户端:12.34。567.891,服务器:网站。com,请求:“GET/gcm_test.php HTTP/1.1”,上游:fastcgi://unix:///var/www/vhosts/system/website.com/php-fpm。主持人:“www.website。com“

Android推送PHP脚本:

<?php
    // Replace with the real server API key from Google APIs
    $apiKey = "my apikey";

    // Replace with the real client registration IDs
    $registrationIDs = array("red id1", "reg id2");

    // Message to be sent
    $message = "Your message e.g. the title of post";

    // Set POST variables
    $url = 'https://gcm-http.googleapis.com/gcm/send';

    $fields = array(
        'registration_ids' => $registrationIDs,
        'data' => array( "message" => $message ),
    );
    $headers = array(
        'Authorization: key=' . $apiKey,
        'Content-Type: application/json'
    );

    // Open connection
    $ch = curl_init();

    // Set the URL, number of POST vars, POST data
    curl_setopt( $ch, CURLOPT_URL, $url);
    curl_setopt( $ch, CURLOPT_POST, true);
    curl_setopt( $ch, CURLOPT_HTTPHEADER, $headers);
    curl_setopt( $ch, CURLOPT_RETURNTRANSFER, true);
    //curl_setopt( $ch, CURLOPT_POSTFIELDS, json_encode( $fields));

    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
    curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode( $fields));

    // Execute post
    $result = curl_exec($ch);

    // Close connection
    curl_close($ch);
    // print the result if you really need to print else neglate this
    echo $result;
?>

如果我替换行“$result=curl\u exec($ch);”用“回声”结束脚本我没有错误,结果是“脚本结束”。因此,问题似乎出在“$result=curl_exec($ch);”行中

我还尝试了以下,PLESK nginx 504错误:网关超时没有运气。

在我的服务器上,我运行PHP7。0.4作为nginx提供的FPM应用程序

有人有什么想法吗?谢谢!

共有1个答案

宋弘壮
2023-03-14

看起来您需要在nginx配置中增加fastcgi\u read\u timeout

 类似资料:
  • 问题内容: 我在synology nas上将nginx 1.12和php-fpm 7.1作为单独的docker容器运行,并且如果php- script运行时间超过60s,则会收到504 Gateway错误。我已经尝试了几个nginx配置参数,但是错误仍然存​​在。 这是我实际的nginx配置: php-testscript: 60秒后,浏览器显示504网关超时。php脚本仍在运行,并且还在将文本写

  • 我正在尝试使用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文件,并验

  • null 我们得出的结论是,客户端可以连接到Nginx,但是Nginx在将请求重定向到FPM(可以通过端口7777访问)时没有收到响应,并显示超时错误。我们一直致力于解决Nginx和FPM之间的通信问题,但几个小时后,我们还没有找到解决方案。 注意:这个问题在我们设置的四个虚拟机中重复出现。 Nginx错误日志(注意:主机名和ip已被取消) 文件:/etc/nginx/fastcgi_params

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

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