Skip to content

Resque plugin to allow (de)queueing of jobs without having the class loaded

Notifications You must be signed in to change notification settings

lafave/resque-remote-namespace

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

resque-remote-namespace is a fork of the remote-namespace gem that allows for remote enqueueing and dequeueing of jobs on different redis namespaces.

Installation

Add it to your Bundler Gemfile:

# Gemfile
gem 'resque-remote-namespace'

And then run bundle install.

Usage

Enqueueing

# 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'

Dequeueing

# 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'

Worker Processing

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

About

Resque plugin to allow (de)queueing of jobs without having the class loaded

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Ruby 100.0%