1

我正在尝试在 Heroku 上使用 ActionController::Live, Pub/Sub(Redis),但它不起作用。我正在使用 Ruby2.0.0p247、Rails4、Puma。

我想做这样的聊天。RailsCast(http://railscasts.com/episodes/401-actioncontroller-live?view=asciicast),GitHub(https://github.com/railscasts/401-actioncontroller-live/tree/master/chatter-after

我的代码是这样的。

初学者消息控制器.rb

class BeginnerMessagesController < ApplicationController

include ActionController::Live

def index
  @beginner_messages = BeginnerMessage.all.order("created_at DESC")

end

def create  
  response.headers["Content-Type"] = "text/javascript"
  attributes = params.require(:beginner_message).permit(:body)
  @beginner_message = BeginnerMessage.new(attributes)
  @beginner_message.user = current_user
  @beginner_message.save

  json_message = @beginner_message.to_json
  hash_result = JSON.parse(json_message)
  hash_result[:username] = @beginner_message.user.username
  hash_result[:created_at] = @beginner_message.created_at.strftime("%H:%M")
  @json_result = hash_result.to_json
  $redis.publish('beginner_messages.create', @json_result)
end

def events
  response.headers["Content-Type"] = "text/event-stream"
  redis = Redis.new
  redis.psubscribe('beginner_messages.*') do |on|
  on.pmessage do |pattern, event, data|
       response.stream.write("event: #{event}\n")
       response.stream.write("data: #{data}\n\n")
     end
   end
 end
rescue IOError
  logger.info "Stream closed"
ensure
  redis.quit
  response.stream.close
end

初学者消息.js.coffee

source = new EventSource('/beginner_messages/events')
source.addEventListener 'beginner_messages.create', (e) ->
  beginner_message = $.parseJSON(e.data)
  $('#chat').prepend($('<li>').text("#{beginner_message.username} $ #{beginner_message.body} #{beginner_message.created_at}").css("listStyleType","none"))

在本地主机上,它可以工作,但在 Heroku 上却不行。Puma 和 Redis 正在研究 Heroku。

我在网上搜索过,但没有任何帮助。请告诉我我应该怎么做。谢谢您的帮助。

4

1 回答 1

0

很抱歉破坏了一个旧线程,但任何其他有此问题的人都可以在他们的终端中尝试这个:

$ heroku labs:enable websockets

于 2014-01-15T03:14:30.607 回答