ngnix不完整地将数据传输到unix域套接字

Sce*_*ule 5 php linux nginx unix-socket

我的应用程序正在侦听传入数据的unix域套接字(UDS),而nginx正在使用PHP发送数据.发送几个KB的较小数据块可以很好地工作,但是一旦达到某个限制,浏览器就会收到错误504 Gateway Time-out,nginx日志

上游超时(110:连接超时)从上游读取响应头,客户端:127.0.0.1,服务器:_,请求:"GET /foo/bar.php HTTP/1.1",上游:"fastcgi:// unix :/run/php/php7.0-fpm.sock",主持人:"localhost"

套接字仍然获取一些数据(总是减少大约1.5 MB)并回复但网络服务器似乎没有得到响应.是否有必须调整的UDS流限制或nginx变量?

PHP代码:

public function send ($msg)
{
    $str = "{$msg}".chr(27);

    $ret = socket_write($this->socket, $str, strlen($str));

    if ($ret == FALSE)
    {
        return false;
    }
    else
    {
        $response = "";

        while (($chunk = socket_read($this->socket, 2048, PHP_BINARY_READ)) !== FALSE)
        {
            $response .= $chunk;

            if (substr($chunk, -1) == chr(27))
                break;
        }

        //close the connection
        if ($this->connected !== false)
        {
            socket_shutdown($this->socket);
            socket_close($this->socket);
            $this->connected = false;
        }

        return $response;
    }
}
Run Code Online (Sandbox Code Playgroud)

Bar*_*n01 1

对于陈述者来说,Nginx 与这个问题无关,很明显 PHP 发送和接收数据。

您的远程系统很可能没有在正确的时间关闭套接字,或者只是需要很长时间才能响应。

while (($chunk = socket_read($this->socket, 2048, PHP_BINARY_READ)) !== FALSE)
{
    $response .= $chunk;
    if (substr($chunk, -1) == chr(27))
    break;
}
Run Code Online (Sandbox Code Playgroud)

如果远程系统没有关闭连接/套接字并告诉您它将继续尝试读取并等待 2048(位或字节 - 我永远不记得哪个),则此代码块有可能成为此代码的无限循环大小,它要求确保注释会通知)要通过的数据或在读取完成之前要关闭的套接字。

因此,有几件事可以尝试降低读取字节数,将其设置为类似的东西128,在套接字中放入一个计时器(需要在 PHP 中进行异步编程)读取,因此在 28 秒后杀死它,给您的代码多 2 秒的执行时间(安全退出) )。或用于 set_time_limit增加您的时间限制。

如果您确实增加了时间限制,则需要增加允许 nginx 从 PHP 连接获取响应的时间,以完成此设置fastcgi_read_timeout