HAProxy + WebSocket断开连接

Ros*_*oss 43 reverse-proxy haproxy websocket node.js

我正在使用HAProxy将子域上的请求发送到node.js应用程序.

我无法让WebSockets工作.到目前为止,我只能让客户端建立WebSocket连接,但之后很快就会出现断开连接.

我在ubuntu上.我一直在使用的各种版本socket.ionode-websocket-server.客户端是Safari或Chrome的最新版本.HAProxy版本是1.4.8

这是我的HAProxy.cfg

global 
    maxconn 4096 
    pidfile /var/run/haproxy.pid 
    daemon 

defaults 
    mode http 

    maxconn 2000 

    option http-server-close
    option http-pretend-keepalive

    contimeout      5000
    clitimeout      50000
    srvtimeout      50000

frontend HTTP_PROXY
    bind *:80 

    timeout client  86400000

    #default server
    default_backend NGINX_SERVERS

    #node server
    acl host_node_sockettest hdr_beg(host) -i mysubdomain.mydomain

use_backend NODE_SOCKETTEST_SERVERS if host_node_sockettest


backend NGINX_SERVERS 
server THIS_NGINX_SERVER 127.0.0.1:8081

backend NODE_SOCKETTEST_SERVERS
timeout queue   5000
timeout server  86400000

server THIS_NODE_SERVER localhost:8180 maxconn 200 check
Run Code Online (Sandbox Code Playgroud)

我已经浏览了网络和邮件列表但无法获得任何建议的解决方案.

(ps这可能是针对serverfault,但是还有其他的HAProxy问题,所以我选择在这里发帖)

Shr*_*hna 60

升级到最新版本的socket.io(0.6.8 - > npm install socket.io@0.6.8,已修补以与HAProxy配合使用)并下载最新版本的HAProxy.

这是一个示例配置文件:

global
    maxconn     4096 # Total Max Connections. This is dependent on ulimit
    nbproc      2

defaults
    mode        http

frontend all 0.0.0.0:80
    timeout client 5000
    default_backend www_backend
    acl is_websocket hdr(Upgrade) -i WebSocket
    acl is_websocket hdr_beg(Host) -i ws

    use_backend socket_backend if is_websocket

backend www_backend
    balance roundrobin
    option forwardfor # This sets X-Forwarded-For
    timeout server 5000
    timeout connect 4000
    server server1 localhost:8081 weight 1 maxconn 1024 check
    server server2 localhost:8082 weight 1 maxconn 1024 check
    server server3 localhost:8083 weight 1 maxconn 1024 check

backend socket_backend
    balance roundrobin
    option forwardfor # This sets X-Forwarded-For
    timeout queue 5000
    timeout server 5000
    timeout connect 5000
    server server1 localhost:8081 weight 1 maxconn 1024 check
    server server2 localhost:8082 weight 1 maxconn 1024 check
    server server3 localhost:8083 weight 1 maxconn 1024 check
Run Code Online (Sandbox Code Playgroud)

  • 如果浏览器客户端回退到xhr轮询或任何其他长轮询样式传输,则此解决方案将中断.为此,您需要http后端使用cookie或源IP哈希(平衡源)方法来确保所有请求都在同一个后端服务器上,即使使用redisstore也是如此. (5认同)
  • 伙计们,请不要使用一天的连接超时,如果您的某个服务器暂时无法访问,它将导致连接累积.几秒钟绰绰有余! (4认同)

kan*_*aka 6

您的客户端可能正在使用WebSockets版本76.在这种情况下,您不能使用"mode http",因为WebSockets握手违反了HTTP.委员会似乎对于WebSockets握手是否应与HTTP兼容存在矛盾心理.无论如何,v76握手的问题是原始数据是通过握手(校验和块)发送的.

相关的HAProxy讨论:http://www.mail-archive.com/haproxy@formilux.org/msg03046.html

从讨论中可以看出,可能存在一种默认为TCP模式的方法,并且对于非WebSockets连接可以回退到HTTP.


Ily*_*lya 5

我们正在使用 Netty 实现https://github.com/ibdknox/socket.io-netty,这里是对我们有用的 HAProxy 文件。让它不回退到 XHR 轮询而是使用 Websockets 的技巧是将 HAProxy 置于 TCP 模式。HAProxy 配置:

global
    daemon
    maxconn 32000

defaults
    mode http
    timeout connect 5000ms
    timeout client 50000ms
    timeout server 50000ms

listen http-in
    bind *:80
    server server1 1.1.1.1:8000 check
    server server2 1.1.1.1:8000 check

listen socketio-in
    mode tcp
    bind *:8080
    balance source
    timeout queue 5000
    timeout server 86400000
    timeout connect 86400000
    server server1 1.1.1.1:8080 check
    server server2  1.1.1.1:8080 check
Run Code Online (Sandbox Code Playgroud)

其中 1.1.1.1 是您的 IP