1

良い一日!Faye gem で websocket アプリを実行したいのですが、次の問題が発生します: アプリを本番サーバーにデプロイすると、Ngix は faye.js を受信できず、faye サーバーに接続できません。Nginx error.log で次のエラーを見つけました:

2014/12/24 15:44:39 [error] upstream prematurely closed connection while reading response header from upstream, client: 46.0.121.23, server: example.com, request: "GET /faye HTTP/1.1", upstream: "http://127.0.0.1:9292/faye", host: "example.com"

2014/12/24 15:44:39 [error] *1 connect() failed (111: Connection refused) while connecting to upstream, client: 46.0.121.23, server: example.com, request: "GET /faye HTTP/1.1", upstream: "http://127.0.0.1:9292/faye", host: "example.com"

dokku を使用してデプロイされた Rails アプリで faye サーバーを起動する方法を試してみますか? NGINX + rails + dokku の Error 502 Bad Gatewayの回答ですが、私には役に立ちません。

私のプロフィールは

web: bundle exec rails s Puma -p 5000
faye: bundle exec rackup s Puma faye.ru

私のfaye.ruは

require 'faye'
require File.expand_path('../config/initializers/faye_token.rb', __FILE__)

class ServerAuth
  def incoming(message, callback)
    if message['channel'] !~ %r{^/meta/}
      if message['ext']['auth_token'] != FAYE_TOKEN
        message['error'] = 'Invalid authentication token.'
      end
    end
    callback.call(message)
  end
end
faye_server = Faye::RackAdapter.new(:mount => '/faye', :timeout => 0)
faye_server.add_extension(ServerAuth.new)
run faye_server

私のnginx.confは次のとおりです。

upstream example.com { server 127.0.0.1:49169; }
server {
  listen      [::]:80;
  listen      80;
  server_name example.com;
  location    / {
    proxy_pass  http://example.com;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
    proxy_set_header Host $http_host;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_set_header X-Forwarded-For $remote_addr;
    proxy_set_header X-Forwarded-Port $server_port;
    proxy_set_header X-Request-Start $msec;
  }
  location /faye {
    proxy_redirect     off;
    proxy_set_header   Upgrade    $http_upgrade;
    proxy_set_header   Connection "upgrade";
    proxy_http_version 1.1;
    proxy_buffering    off;
    proxy_cache_bypass $http_pragma $http_authorization;
    proxy_no_cache     $http_pragma $http_authorization;
    proxy_pass http://localhost:9292;
  }
}

私のアプリは次に faye.js を取得します:

<%= javascript_include_tag "http://example.com/faye.js" %>

そしてfayeサーバーに接続します

$(function() {
    var faye = new Faye.Client('http://example.com/faye');
    faye.subscribe('/comments/new', function (data) {
        eval(data);
    });
});

私に何ができる?開発環境ではすべて正常に動作しますが、本番環境ではエラーのみです。

4

1 に答える 1

0

この要点から構成してみて ください https://gist.github.com/Bubelbub/0a942a0d51a3d329897d

サーバーセクションで:

large_client_header_buffers 8 32k;

フェイの場所:

 proxy_buffers 8 32k;
 proxy_buffer_size 64k;
于 2015-03-11T14:20:09.377 に答える