Redis
 sql >> Datenbank >  >> NoSQL >> Redis

Resque, Resque Server, auf RedisToGo mit Heroku

Ich denke dein Procfile hat einen Tippfehler. Warum haben Sie zwei web Prozesse? Ich würde bei einem bleiben und Einhorn verwenden .

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

Bei Verwendung von Einhorn mit resque , müssen Sie die resque definieren redis Verbindung jedes Mal Einhorn Gabeln. Hier sind die relevanten Dateien.

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

Siehe diesen Kern für die vollständige unicorn.rb