resque-remote-namespace
is a fork of the remote-namespace gem that allows for remote enqueueing and dequeueing of jobs on different redis namespaces.
Add it to your Bundler Gemfile
:
# Gemfile
gem 'resque-remote-namespace'
And then run bundle install
.
# Enqueues TestJob to the "default" queue on the "resque:foo" redis namespace with "foo" as its sole argument.
Resque.remote_enqueue_to 'default', 'resque:foo', 'TestJob', 'foo'
# Enqueues TestJob to the "default" queue on the "resque:foo" redis namespace in 5 minutes with "foo" as its sole argument. (Uses resque-scheduler gem)
Resque.remote_enqueue_to_in 5.minutes, 'default', 'resque:foo', 'TestJob', 'foo'
# Dequeues TestJob from the "default" queue on the "resque:foo" redis namespace with "foo" as its sole argument
Resque.remote_dequeue_from 'default', 'resque:foo', 'TestJob', 'foo'
The job you are remotely enqueueing does not need to exist in the application you are in enqueueing it from, however if Resque.inline
is set to true
(as is often the case in a development or test environment) then Resque may attempt to execute the job in the current application, depending on which version of Resque you are using. This will cause a NameError
to be raised.
To fix this, just create a stub of the job you are remote enqueueing. Ex:
# Stub of TestJob. Actual implementation is located in X.
class TestJob
def self.perform(*args) end
end
Note that the actual implementation of the remote job does not need to have its @queue
defined.
class TestJob
# no queue needed
def self.perform(*args)
...
end
end