2016-08-25 49 views
1

我使用的运动鞋的宝石来触发的RabbitMQ 的行动,但我不能启动我的服务触发Ruby on Rails的错误使用运动鞋与RabbitMQ的

我运行命令

WORKERS=MailerWorker rake sneakers:run 

,我得到了误差

[INFO] 160825 14:26:46 :: LAUNCH worker 
rake aborted! 
NameError: uninitialized constant ApplicationCable::ActionCable 
/home/hdthinh/wthapps/admin-api/app/channels/application_cable/channel.rb:3:in `<module:ApplicationCable>' 
/home/hdthinh/wthapps/admin-api/app/channels/application_cable/channel.rb:2:in `<top (required)>' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/activesupport/lib/active_support/dependencies/interlock.rb:12:in `block in loading' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/activesupport/lib/active_support/concurrency/share_lock.rb:149:in `exclusive' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/activesupport/lib/active_support/dependencies/interlock.rb:11:in `loading' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/railties/lib/rails/engine.rb:476:in `block (2 levels) in eager_load!' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/railties/lib/rails/engine.rb:475:in `each' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/railties/lib/rails/engine.rb:475:in `block in eager_load!' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/railties/lib/rails/engine.rb:473:in `each' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bundler/gems/rails-804f5b3c2af9/railties/lib/rails/engine.rb:473:in `eager_load!' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/gems/sneakers-2.3.5/lib/sneakers/tasks.rb:13:in `block (2 levels) in <top (required)>' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/gems/rake-11.2.2/exe/rake:27:in `<top (required)>' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bin/ruby_executable_hooks:15:in `eval' 
/home/hdthinh/.rvm/gems/ruby-2.3.0/bin/ruby_executable_hooks:15:in `<main>' 

我的代码如下所示

# Rakefile 
require_relative 'config/application' 
require 'sneakers/tasks' 

Rails.application.load_tasks 


# config/initializers/sneakers.rb 
Sneakers.configure({}) 
Sneakers.logger.level = Logger::INFO 

# app/workers/mailer_worker.rb 
require 'sneakers' 
class MailerWorker 
    include Sneakers::Worker 

    from_queue "test.user.login", env: nil 

    def work(raw_post) 
    p "you are successful in this queue! #{raw_post.to_s}" 
    ack! # we need to let queue know that message was received 
    end 
end 

我的RabbitMQ也有消息在交换“test.user.login”

我遵循这个文章,但发生的错误 Rails: How to listen to/pull from service or queue?

如何运行的球鞋没有错误

感谢

+0

这是有帮助的http://stackoverflow.com/questions/34396006/uninitialized-constant-actioncableserverconfigurationapplicationcable –

+0

嗨@HieuPham,感谢 我已经加入这一行 需要“action_cable” 到文件“的config/application.rb中' 它运作良好 –

回答

0

错误提示ActionCable在您的脚本中不可用,您应该在您的脚本中安装/需要它。