用于Playframework Websockets的VHosts Nginx配置

时间:2012-02-21 05:36:46

标签: nginx playframework websocket

下面的配置似乎已经奏效,但现在它失败了。我按照这个article下载并安装了tcp_proxy_module。

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    #server {

    #}


    # another virtual host using mix of IP-, name-, and port-based configuration

    server {
        listen       80;
       #listen       locahost:8080;
        server_name  localhost.in;

        location / {
            proxy_pass http://127.0.0.1:9000;
        proxy_set_header        Host            $host;
         }
    }

}

更新

Nginx错误日志:

2012/02/21 10:56:59 [error] 14745#0: *278 upstream timed out (60: Operation timed out) while reading upstream, client: 127.0.0.1, server: localhost.in, request: "GET /websocket/room/socket?roomNo=1&user=sameerFF HTTP/1.1", upstream: "http://127.0.0.1:9000/websocket/room/socket?roomNo=1&user=sameerFF", host: "test.localhost.in"
2012/02/21 10:56:59 [error] 14745#0: *257 upstream timed out (60: Operation timed out) while reading upstream, client: 127.0.0.1, server: localhost.in, request: "GET /websocket/room/socket?roomNo=1&user=sameerChrome HTTP/1.1", upstream: "http://127.0.0.1:9000/websocket/room/socket?roomNo=1&user=sameerChrome", host: "test.localhost.in"
2012/02/21 10:59:40 [error] 15366#0: *10 upstream timed out (60: Operation timed out) while reading upstream, client: 127.0.0.1, server: localhost.in, request: "GET /websocket/room/socket?roomNo=1&user=sameerFF HTTP/1.1", upstream: "http://127.0.0.1:9000/websocket/room/socket?roomNo=1&user=sameerFF", host: "test.localhost.in"

更新2:

使用此配置,当我启动nginx时会出现绑定异常。如果我删除了tcp设置,nginx就可以了。对于常规http请求以及WebSocket请求,我需要端口80重定向到9000

#user  nobody;
worker_processes  1;

error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}

tcp {
     upstream websockets {
      ## Play! location
       server 127.0.0.1:9000;
     }   

    server {
        listen 80;
        server_name localhost.in;

        tcp_nodelay on;
        proxy_pass websockets;
   }
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    # another virtual host using mix of IP-, name-, and port-based configuration

    server {
        listen       80;
#listen       locahost:8080;
        server_name  localhost.in;

        location / {
            proxy_pass http://127.0.0.1:9000;
        proxy_set_header        Host            $host;
    }
    }

}

1 个答案:

答案 0 :(得分:5)

看起来它只是不起作用的websockets。请再次阅读article you linked。您没有修改nginx配置。

根据那篇文章,您的示例配置可能如下所示(我还没有测试过):

tcp {
    upstream websockets {
        ## Play! location
        server 127.0.0.1:9000;
    }   

    server {
        listen 80;
        server_name localhost.in;

        tcp_nodelay on;
        proxy_pass websockets;
    }
}