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)
对于陈述者来说,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
| 归档时间: |
|
| 查看次数: |
151 次 |
| 最近记录: |