簡體   English   中英

用於Playframework Websocket的VHosts Nginx Config

[英]VHosts Nginx Config for Playframework Websockets

下面的配置似乎已經起作用,但是現在失敗了。 我按照本文下載並安裝了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;
    }
    }

}

看來只是websockets無法正常工作。 請再次閱讀您鏈接文章 您沒有修改您的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;
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM