我已经尝试让Resque (使用Resque服务器)& RedisToGo在heroku (雪松)上工作了一段时间,但是我一直遇到这样的错误:
Redis::CannotConnectError (Error connecting to Redis on 127.0.0.1:6379 (ECONNREFUSED)):它在本地工作,我可以在Heroku的控制台上为我的应用程序访问redis。
我的专利文件有:
web: bundle exec thin start -p $PORT -e $RACK_ENV
web: bundle exec unicorn -p $PORT -c ./config/unicorn.rb
resque: env TERM_CHILD=1 RESQUE_TERM_TIMEOUT=10 bundle exec rake resque:work我的Gemfile:
gem 'redis'
#Background queue
gem 'resque', '~> 1.22.0', :require => "resque/server"lib/任务/resque.rake:
require 'resque/tasks'
task "resque:setup" => :environment do
ENV['QUEUE'] = '*'
end
desc "Alias for resque:work (To run workers on Heroku)"
task "jobs:work" => "resque:work"routes.rb:
mount Resque::Server.new, :at => "/resque" 初始化器: redis.rb:
uri = URI.parse(ENV["REDISTOGO_URL"])
REDIS = Redis.new(:host => uri.host, :port => uri.port, :password => uri.password)
Resque.redis = REDISresque.rb:
Dir["#{Rails.root}/app/workers/*.rb"].each { |file| require file }
Resque.after_fork = Proc.new { ActiveRecord::Base.establish_connection }然后,在我的应用程序/工人目录中,我有类似于myjob.rb的东西
我觉得我要在这里绕圈,有什么想法吗?
发布于 2013-01-31 22:05:29
我想你的Procfile有一个错误。为什么有两个web进程?我会坚持用独角兽。
web: bundle exec unicorn -p $PORT -c ./config/unicorn.rb
当使用独角兽时,你必须定义每一次独角兽叉的红色连接。这是相关的文件。
配置/初始化器/redis.rb
uri = URI.parse(ENV["REDIS_WORKER"])
REDIS_WORKER = Redis.new(host: uri.host, port: uri.port, password: uri.password)配置/初始化器/resque.rb
Resque.redis = REDIS_WORKERconfig/unicorn.rb
before_fork do |server, worker|
if defined?(Resque)
Resque.redis.quit
Rails.logger.info("Disconnected from Redis")
end
end
after_fork do |server, worker|
if defined?(Resque)
Resque.redis = REDIS_WORKER
Rails.logger.info("Connected to Redis")
end
end有关完整的gist,请参阅此unicorn.rb
https://stackoverflow.com/questions/12256476
复制相似问题