diff options
Diffstat (limited to 'lib/killjoy/rmq/message_bus.rb')
| -rw-r--r-- | lib/killjoy/rmq/message_bus.rb | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/lib/killjoy/rmq/message_bus.rb b/lib/killjoy/rmq/message_bus.rb new file mode 100644 index 0000000..710e4cd --- /dev/null +++ b/lib/killjoy/rmq/message_bus.rb @@ -0,0 +1,75 @@ +module Killjoy + class MessageBus + attr_reader :configuration + + def initialize(configuration = AMQPConfiguration.new) + @configuration = configuration + @subscriptions = Queue.new + @cpus = Facter.value('processors')['count'].to_i + end + + def subscribe(consumer) + options = { manual_ack: true, block: false } + queue = create_queue(consumer) + subscription = queue.subscribe(options) do |info, metadata, raw_message| + begin + message = Message.new(raw_message, info, channel) + if block_given? + yield message + else + consumer.work(message) + end + rescue => error + Killjoy.logger.error(error.message) + message.reject! + end + end + @subscriptions << subscription + end + + def stop + while @subscriptions.size > 0 + @subscriptions.deq.cancel + end + connection.close + end + + def publish(message) + message.publish_to(exchange) + end + + private + + def connection + @connection ||= Bunny.new( + configuration.amqp_uri, + heartbeat: configuration.heartbeat, + logger: Killjoy.logger + ).tap do |connection| + connection.start + end + end + + def channel + @channel ||= connection.create_channel(nil, @cpus).tap do |x| + x.prefetch(configuration.prefetch) + end + end + + def exchange + @exchange ||= channel.exchange( + configuration.exchange, + durable: true, + type: configuration.exchange_type + ) + end + + def create_queue(consumer) + queue = channel.queue(consumer.queue_name, exclusive: false, durable: true) + consumer.bindings.each do |binding| + queue.bind(exchange, routing_key: binding) + end + queue + end + end +end |
