weinig verwachtingen eerst.
Je hebt een config/resque_config.rb
of vergelijkbaar zoals:
require 'rubygems'
require 'resque' # include resque so we can configure it
require 'resque/server'
require 'resque_scheduler'
require 'resque_scheduler/server'
require 'yaml'
Resque.redis.namespace = "resque:api"
rails_root = ENV['APP_ROOT'] || (File.dirname(__FILE__) + '/..')
# require File.expand_path(File.join(rails_root,"lib","extensions","resque","worker.rb"))
rails_env = RAILS_ENV if defined? RAILS_ENV
rails_env ||= ( ENV['RAILS_ENV'] || 'development' )
resque_config = YAML.load_file(File.join(rails_root, 'config/resque.yml'))
Resque.redis = resque_config[rails_env]
# IN THIS ORDER
Resque::Scheduler.dynamic = true
Resque.schedule = YAML.load_file(File.join(rails_root, 'config/resque_schedule.yml')) # load the schedule
en een config/resque.yml
of vergelijkbaar zoals:
development: localhost:6379
test: localhost:6379
integration: localhost:6379
staging: localhost:6379
production: localhost:6379
De integration
zou ofwel op / communiceren met een andere server of een andere poort gebruiken. Dan zou je het zijn eigen Redis-server laten draaien, zodat de 2 elkaar niet overlappen. Ik neem aan dat je niet wilde dat de productie en integratie de dingen op dezelfde plek in de wachtrij zetten?