Class: Chef::Util::ThreadedJobQueue
- Inherits:
-
Object
- Object
- Chef::Util::ThreadedJobQueue
- Defined in:
- lib/chef/util/threaded_job_queue.rb
Overview
A simple threaded job queue
Create a queue:
queue = ThreadedJobQueue.new
Add jobs:
queue << lambda { |lock| foo. }
A job is a callable that optionally takes a Mutex instance as its only parameter.
Then start processing jobs with +n+ threads:
queue.process(n)
Instance Method Summary collapse
- #<<(job) ⇒ Object
-
#initialize ⇒ ThreadedJobQueue
constructor
A new instance of ThreadedJobQueue.
- #process(concurrency = 10) ⇒ Object
Constructor Details
#initialize ⇒ ThreadedJobQueue
Returns a new instance of ThreadedJobQueue.
36 37 38 39 |
# File 'lib/chef/util/threaded_job_queue.rb', line 36 def initialize @queue = Queue.new @lock = Mutex.new end |
Instance Method Details
#<<(job) ⇒ Object
41 42 43 |
# File 'lib/chef/util/threaded_job_queue.rb', line 41 def <<(job) @queue << job end |
#process(concurrency = 10) ⇒ Object
45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/chef/util/threaded_job_queue.rb', line 45 def process(concurrency = 10) workers = (1..concurrency).map do Thread.new do loop do fn = @queue.pop fn.arity == 1 ? fn.call(@lock) : fn.call end end end workers.each { |worker| self << Thread.method(:exit) } workers.each(&:join) end |