Skip to content

[NOT MAINTAINED] A plugin for Resque that forks X children, processes all jobs in the queue and all processes quit when there are no more jobs to complete

License

Notifications You must be signed in to change notification settings

iwarshak/resque-batchworker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

resque-batchworker

Works with Resque 1.8.5

Resque::Plugins::Batchworker is an alternative to the standard Worker class.

This class works by forking X children, which all work until there are no more jobs to run, and then all of the children quit. Note that the traditional Worker will fork for every single job. This class will not do that. Keep that in mind.

This was written for a situation where hundreds of thousands of jobs get queued throughout the day but ONLY wanted them to be processed during off-peak hours (i.e. middle of the night)

To use Batchworker, run this:

require 'resque/plugins/batchworker'
Resque::Plugins::Batchworker.initiate_work NUMBER_OF_PROCESSES, QUEUE_NAME

Thanks to Facilities Technology Group for allowing this code to be released publicly.

Note on Patches/Pull Requests

  • Fork the project.

  • Make your feature addition or bug fix.

  • Add tests for it. This is important so I don’t break it in a future version unintentionally.

  • Commit, do not mess with rakefile, version, or history. (if you want to have your own version, that is fine but bump version in a commit by itself I can ignore when I pull)

  • Send me a pull request. Bonus points for topic branches.

Copyright © 2010 Ian Warshak. See LICENSE for details.

About

[NOT MAINTAINED] A plugin for Resque that forks X children, processes all jobs in the queue and all processes quit when there are no more jobs to complete

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages