Sha256: 31303ae381ff89fdebf8500cca91529396d514076bd991fc4735d6b6a9da1a14

Contents?: true

Size: 1.43 KB

Versions: 28

Compression:

Stored size: 1.43 KB

Contents

require "thread"

module GorgonBunny
  # Thread pool that dispatches consumer deliveries. Not supposed to be shared between channels
  # or threads.
  #
  # Every channel its own consumer pool.
  #
  # @private
  class ConsumerWorkPool

    #
    # API
    #

    attr_reader :threads
    attr_reader :size

    def initialize(size = 1)
      @size  = size
      @queue = ::Queue.new
    end


    def submit(callable = nil, &block)
      @queue.push(callable || block)
    end

    def start
      @threads = []

      @size.times do
        t = Thread.new(&method(:run_loop))
        @threads << t
      end

      @running = true
    end

    def running?
      @running
    end

    def shutdown
      @running = false

      @size.times do
        submit do |*args|
          throw :terminate
        end
      end
    end

    def join(timeout = nil)
      @threads.each { |t| t.join(timeout) }
    end

    def pause
      @running = false

      @threads.each { |t| t.stop }
    end

    def resume
      @running = true

      @threads.each { |t| t.run }
    end

    def kill
      @running = false

      @threads.each { |t| t.kill }
    end

    protected

    def run_loop
      catch(:terminate) do
        loop do
          callable = @queue.pop

          begin
            callable.call
          rescue Exception => e
            # TODO
            puts e.class.name
            puts e.message
          end
        end
      end
    end
  end
end

Version data entries

28 entries across 28 versions & 1 rubygems

Version Path
gorgon-0.11.1 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.11.0 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.10.5 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.10.4 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.10.3 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.10.2 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.10.1 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.10.0 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.9.0 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.8.4 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.8.3 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.8.2 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.8.1 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.8.0 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.7.1 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.7.0 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.7.0.rc4 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.7.0.rc3 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.7.0.rc2 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb
gorgon-0.7.0.rc1 lib/gorgon_bunny/lib/gorgon_bunny/consumer_work_pool.rb