Неопределенный метод `close_connection_after_writing'
У меня есть проект на рельсах 3 с мультиплеером с использованием Faye. Ошибка
block in close': undefined method
close_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. Получатель этого метода является объектом соединения, поэтому я думаю, что эта ошибка означает, что соединение было разорвано ненадлежащим образом или не было создано.