Неопределенный метод `close_connection_after_writing'

У меня есть проект на рельсах 3 с мультиплеером с использованием Faye. Ошибка

block in close': undefined methodclose_connection_after_writing'для nil:NilClass (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>'

после запуска моего фай сервера с командой

Рэкап фэй.ру -с худое -Е производство

Что я могу сделать с такой ошибкой?? Что вызывает это? Как я могу справиться с этим?

4 ответа

Решение

Я нашел на этой странице http://habrahabr.ru/sandbox/45416/

добавьте это в свой файл faye.ru

Faye::WebSocket.load_adapter('тонкий')

это сделало мое решение

я надеюсь, что это помогает спасибо за совет

Не использовать rackup начать Фэй
вместо этого используйте thin start -R faye.ru -e production
это мой файл faye.ru

# 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

Я также столкнулся с этой проблемой после обновления Фэй.

Чтобы построить ответ @tingel2k, вам нужно вставить это:

Faye::WebSocket.load_adapter('thin')

в faye.ru до запуска приложения, например:

run Faye::RackAdapter.new(...)

Это ошибка EventMachine. Получатель этого метода является объектом соединения, поэтому я думаю, что эта ошибка означает, что соединение было разорвано ненадлежащим образом или не было создано.

Другие вопросы по тегам