Faye Websocket Error Rails 2.2.2 (производство)

Я использую Faye на 2.1.3 без проблем, но после обновления до 2.2.2 я могу заставить работать только локальный экземпляр. Производственные веб-сокеты терпят неудачу. Я заменил фактическое имя сервера на blahblahserver.com.

Фэй Рэкап

require 'faye'
app = Faye::RackAdapter.new(:mount => '/faye', :timeout => 25)
Faye::WebSocket.load_adapter('thin')
run app

Приложение.html.erb

<%= javascript_include_tag "application",params[:controller],'http://app-server1.blahblahserver.com:9292/faye/faye.js','data-turbolinks-track' => true %>

Помощник (функция отправки)

def broadcast(channel, &block)
  message = {:channel => channel, :data => capture(&block)}
  uri = URI.parse("http://localhost:9292/faye")
  Net::HTTP.post_form(uri, :message => message.to_json)
end

В контроллере Rails

gon.env = Rails.env

Слушатель (Coffeescript)

$ ->
  # required when faye listener is present to keep from having hard env changes
  # parallel gon.env = Rails.env in controller must be present
  server_name = undefined
  switch gon.env
    when "production"
     server_name = 'app-server1.blahblahserver.com'
    when "staging"
     server_name = 'si-staging.blahblahserver.com'
    when "development"
     server_name = 'localhost'
  address = 'http://' + server_name + ':9292/faye'

# Listener for this page locally
faye = new (Faye.Client)(address)
faye.subscribe ('/logs/'+gon.property_id+ '/new'), (data) ->
 if getParameterByName('all_open') == "true"
  window.location.href = window.location.href
 else if  gon.today == gon.display_date
  ready(data)
 else window.location.href = window.location.href
return
faye.subscribe ('/logs/'+gon.property_id+ '/alert'), (data) ->
 console.log('pre-ajax')
 $.ajax 'load_customer_messages' ,
  type: "GET",
  dataType: "JSON",
  asnyc: false,
  success: (data2) ->
    $('#ajax').click()
 return
return

ready = (data) ->
 eval data 

person Keith    schedule 09.08.2015    source источник


Ответы (1)


Итак, проблема заключается в обновлении Фэй. Синтаксис для запуска сейчас выглядит следующим образом:

Rackup --host [ip-адрес сервера] faye.ru -s thin -E production -D Добавление -- host [ip-адрес] теперь требуется, так как Rackup больше не слушает извне без ip-адреса.

6 дней разочарований, на сайте файе нет документации!

person Keith    schedule 14.08.2015