socket.io,netty-socketio,nginx每分钟断开连接

时间:2015-02-19 20:05:42

标签: javascript nginx websocket socket.io netty

我在端口netty-socketio上运行了9092服务器。 nginx配置为侦听端口9093和对netty-socketio服务器的代理请求(两者当前都在同一服务器上运行,但在生产中将分开一次)。

如果我直接连接到套接字服务器,一切都按预期工作,但是当通过nginx连接连接时,每隔一分钟就会丢失并重新连接。

非常简化的客户端示例:

<!DOCTYPE html>
<html>
    <head>
        <script src="https://cdn.socket.io/socket.io-1.3.4.js"></script>
        <script>
            var socket = io.connect('http://1.1.1.1:9093');

            socket.on('connect', function ()
            {
                console.log('connected to socket server');
            });

            socket.on('disconnect', function ()
            {
                console.log('lost connection to socket server');
            });
        </script>
    </head>
</html>

nginx config:

upstream socketserver {
    server 127.0.0.1:9092;
}

server {
    listen 9093;
    location / {
        proxy_pass http://socketserver;
        proxy_http_version 1.1;
        proxy_pass_header Server;
        proxy_pass_header Connection;
        proxy_pass_header Date;
    }
}

我能找到的唯一区别是Connection: Upgrade标题设置为大写&#34; U&#34;使用nginx时直接连接和全部小写(&#34;升级&#34;)。我甚至从源代码重新编译nginx但是大写&#34; U&#34;并没有什么区别。

非常感谢任何帮助。感谢。

2 个答案:

答案 0 :(得分:0)

尝试在上游部分添加keepalive

...
keepalive 60;

答案 1 :(得分:0)

在尝试使用默认值60s的指令后,我发现罪魁祸首是proxy_read_timeout。在server上下文中添加此内容为我解决了问题:

proxy_read_timeout 86400s;

有关此指令的文档here