ActionCable“订阅”方法未被调用

时间:2017-07-14 16:16:59

标签: ruby-on-rails ruby actioncable

我有一个ActionCable频道,其“订阅”方法似乎永远不会被调用。

在Rails日志和Javascript控制台中,我可以看到正在建立连接:

I, [2017-07-14T16:02:28.759843 #10658]  INFO -- : [ActionCable]  Registered connection (Z2lkOi8vd2ViY2FzdC9Vc2VyLzM0NQ)
...
I, [2017-07-14T16:14:18.594274 #12208]  INFO -- : [2cdfb51d-e500-49bd-8d7d-c941b8b2bb8a] Successfully upgraded to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: Upgrade, HTTP_UPGRADE: websocket)

app / assets / javascripts / channel / chats.coffee(下面)中的代码似乎被调用:

 ... 
 App.global_chat = App.cable.subscriptions.create {
      channel: "ChatsChannel"
      chat_room_id: $("#chat_room_id").val()
      user_agent: navigator.userAgent
    },
 ...

当浏览器控制台显示聊天对象时,它看起来像预期的那样:

> App.global_chat
< Subscription {consumer: Consumer, identifier: "{"channel":"ChatsChannel","chat_room_id":"32","use… like Gecko) Chrome/58.0.3029.110 Safari/537.36"}", connected: function, disconnected: function, received: function…}
...

但是日志中没有显示ChatsChannel“subscribed”方法(粘贴在下面),并且永远不会调用“register_connection”方法。

# app/channels/chats_channel.rb
class ChatsChannel < ApplicationCable::Channel

  def subscribed
    logger.add_tags 'ActionCable', "subscribing"
    logger.info("subscribing")
    stream_from "chat_rooms_#{params['chat_room_id']}_channel"
    current_user.register_connection(params[:chat_room_id], params[:user_agent])
  end
  ...
end

有什么想法?我对ActionCable很新。我能找到的所有文档都说“订阅”方法只是在连接注册时自动调用,这似乎是,所以我无法弄清楚这里出了什么问题。

这是actioncable 5.0.1。

有没有办法通过Javascript强制使用ruby“订阅”方法?

2 个答案:

答案 0 :(得分:0)

原来,问题是我的redis服务器没有在后台运行。在Rails应用程序之外运行var activate = Flickity.prototype.activate; Flickity.prototype.activate = function() { if ( this.isActive ) { return; } activate.apply( this, arguments ); this.dispatchEvent('ready'); }; 解决了这个问题!

答案 1 :(得分:0)

别忘了也将config/cable.yml调整为redis:

development:
  adapter: redis

并将其添加到您的Gemfile

gem 'redis'