Redis
 sql >> Database >  >> NoSQL >> Redis

Resque, Resque Server, su RedisToGo con Heroku

Penso che il tuo Procfile ha un errore di battitura. Perché hai due web processi? Io ne rimarrei uno e userei unicorn .

web: bundle exec unicorn -p $PORT -c ./config/unicorn.rb

Quando si utilizza unicorno con resque , devi definire il resque redis connessione ogni volta unicorno forchette. Ecco i file rilevanti.

config/initializers/redis.rb

uri = URI.parse(ENV["REDIS_WORKER"])
REDIS_WORKER = Redis.new(host: uri.host, port: uri.port, password: uri.password)

config/initializers/resque.rb

Resque.redis = REDIS_WORKER

config/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

Vedi questo succo per l'unicorn.rb completo