Node.js上的Server-Sent Events连接超时通过Nginx

时间:2014-02-07 14:41:37

标签: node.js nginx server-sent-events

我通过Nginx设置有一个Node.js,它涉及Server-Sent Events。

无论我有什么Nginx配置,sse的连接在60秒后被破坏并再次重新初始化。如果我直接在哪个节点上为其提供服务的端口连接到应用程序,就不会发生这种情况,因此显然存在一些Nginx代理问题。

我想在sse连接上没有超时。那可能吗?我尝试过调整send_timeoutkeepalive_timeoutclient_body_timeoutclient_header_timeout,但它不会改变任何内容。下面是我的Nginx配置。

upstream foobar.org {
   server 127.0.0.1:3201;
}

server {
  listen 0.0.0.0:80;
  server_name   example.org;

  client_max_body_size 0;
  send_timeout 600s;

  location / {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header Host $http_host;
    proxy_set_header X-NginX-Proxy true;

    proxy_pass http://example.org/;
    proxy_redirect off;

    proxy_set_header Connection '';
    proxy_http_version 1.1;
    chunked_transfer_encoding off;
    proxy_buffering off;
    proxy_cache off;
  }
}

1 个答案:

答案 0 :(得分:7)

回答自己。实际上解决方案并不难找到,它只是需要仔细研究nginx文档。

proxy_read_timeout是对此负责的指令,默认情况下它设置为60秒。所以可以通过设置例如:

来轻松修复它
proxy_read_timeout 24h;

设置0无法正常工作,实际上会破坏所有连接,因此我们需要提供足够长的超时时间。

在修复之后我也接近了另一个问题,但这次与浏览器如何处理连接有关。由于某些原因,在5分钟不活动后,浏览器会以静默方式丢弃连接。更糟糕的是,没有任何一方被告知它被丢弃,因为它仍然看起来好像连接在线,但数据没有通过。修复这个问题是在间隔的基础上发送一些保持活动的ping(普通sse评论工作得很好)。