2

Fayeを使用したマルチプレイヤーのRails3でのプロジェクトがあります。エラー

block in close': undefined methodnil:NilClassのclose_connection_after_writing'(NoMethodError)

from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@chats/gems/faye-websocket-0.4.5/lib/faye/websocket/api.rb:89:in `call'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@chats/gems/faye-websocket-0.4.5/lib/faye/websocket/api.rb:89:in `close'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@chats/gems/faye-websocket-0.4.5/lib/faye/websocket.rb:198:in `fail'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/thin-1.3.1/lib/thin/connection.rb:155:in `unbind'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/eventmachine-0.12.10/lib/eventmachine.rb:1417:in `event_callback'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `run_machine'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/eventmachine-0.12.10/lib/eventmachine.rb:256:in `run'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/thin-1.3.1/lib/thin/backends/base.rb:61:in `start'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/thin-1.3.1/lib/thin/server.rb:159:in `start'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/rack-1.4.1/lib/rack/handler/thin.rb:13:in `run'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/rack-1.4.1/lib/rack/server.rb:265:in `start'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/rack-1.4.1/lib/rack/server.rb:137:in `start'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@global/gems/rack-1.4.1/bin/rackup:4:in `<top (required)>'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@chats/bin/rackup:19:in `load'
    from /Users/ostap/.rvm/gems/ruby-1.9.3-p125@chats/bin/rackup:19:in `<main>'

コマンドでフェイサーバーを起動した後

ラックアップfaye.ru-sシン-Eプロダクション

そのようなエラーで何ができますか?何がそれを引き起こしますか?どうすれば処理できますか?

4

4 に答える 4

7

このページで見つけました (ロシア語です) http://habrahabr.ru/sandbox/45416/

これを faye.ru ファイルに追加します

Faye::WebSocket.load_adapter('thin')

これが私の解決策になりました

アドバイスに感謝します

于 2012-06-26T08:48:03.253 に答える
1

代わりにfayerackupを開始するために使用しないでください。 これは私のfaye.ruファイルです。
thin start -R faye.ru -e production

# encoding: utf-8
require 'faye'
require File.expand_path('../config/initializers/faye_token.rb', __FILE__)

Faye::WebSocket.load_adapter('thin')

class ServerAuth
  def incoming(message, callback)
    if message['channel'] !~ %r{^/meta/}
      if message['ext']['auth_token'] != FAYE_TOKEN
        message['error'] = 'Token de autenticacao invalido'
      end
    end
    callback.call(message)
  end
end

bayeux = Faye::RackAdapter.new(:mount => '/faye', :timeout => 25, :extensions => [ServerAuth.new])
run bayeux
于 2012-06-28T20:22:38.730 に答える
1

fayeをアップグレードした後、私もこの問題に遭遇しました。

@ tingel2kの回答に基づいて構築するには、これを挿入する必要があります:

Faye::WebSocket.load_adapter('thin')

faye.ruアプリが開始される前に、例えば:

run Faye::RackAdapter.new(...)
于 2012-06-28T20:20:08.637 に答える
0

これは EventMachine エラーです。このメソッドレシーバーは接続オブジェクトなので、このエラーは接続が適切に終了されていないか、作成されていないことを意味していると思います。

于 2012-06-01T14:57:27.560 に答える