2012-05-01 114 views
0

我的配置文件:HAProxy的不匹配路径(与express.js&Socket.IO)

global 
    maxconn  4096 # Total Max Connections. This is dependent on ulimit 
    nbproc  2 
    daemon 
    log   127.0.0.1 local1 notice 
defaults 
    mode  http 

frontend all 0.0.0.0:80 
    timeout client 86400000 
    default_backend www_backend 
    acl is_websocket hdr(Upgrade) -i WebSocket 
    acl is_websocket hdr_beg(Host) -i ws 
    acl is_websocket path_beg /socket.io 

    use_backend socket_backend if is_websocket 

backend www_backend 
    balance roundrobin 
    option forwardfor # This sets X-Forwarded-For 
    timeout server 30000 
    timeout connect 4000 
    server server1 localhost:9001 weight 1 maxconn 1024 check 
    server server2 localhost:9002 weight 1 maxconn 1024 check 

backend socket_backend 
    balance roundrobin 
    option forwardfor # This sets X-Forwarded-For 
    stats enable 
    timeout queue 5000 
    timeout server 86400000 
    timeout connect 86400000 
    server server1 localhost:5000 weight 1 maxconn 1024 check 

至于我可以告诉www_backend匹配一切。当我的网络应用程序请求http://myapp.com/socket.io/1/?t=1335831853491时,它返回一个404,并且标题显示来自Express的响应。奇怪的是,当我蜷缩-I http://myapp.com/socket.io/1/?t=1335831853491返回:

HTTP/1.1 200 OK 
Content-Type: text/plain 
Connection: keep-alive 

当我执行sudo netstat的-lptu我可以证实,我的socket.io过程在端口5000的任何想法运行?

回答

1

同意上述回应。顺便说一句,你不应该使用TCP连接的1天超时来建立(超时连接),它根本就没有意义,并且会在服务器关闭时导致连接累积。连接(特别是本地连接)应该是立即建立的 。我倾向于为连接设置5秒的超时时间,即使在慢速网络中也足够远。

关于其他长期超时,我正计划实施“超时隧道”,以便用户不必为正常流量使用那么长的超时。

+0

Willy,1天超时似乎是socket.io的鼓励http://stackoverflow.com/questions/4360221/haproxy-websocket-disconnection/4737648#4737648。也许发布在那里和https://github.com/learnboost/socket.io/wiki/可能会帮助别人不会犯同样的错误,我做到了!感谢您的帮助。 – LDK