sonian / carrot forked from famoseagle/carrot

A synchronous amqp client

This URL has Read+Write access

carrot /
name age message
file .gitignore Fri Mar 20 17:23:39 -0700 2009 Initial commit to carrot. [famoseagle]
file LICENSE Wed Apr 08 16:01:05 -0700 2009 adding examples and readme [famoseagle]
file README.markdown Thu Apr 23 19:33:10 -0700 2009 more README changes [famoseagle]
file Rakefile Wed Apr 08 16:01:05 -0700 2009 adding examples and readme [famoseagle]
file VERSION.yml Wed Aug 26 12:06:47 -0700 2009 Version bump to 0.7.0 [famoseagle]
file carrot.gemspec Loading commit data...
directory lib/
directory protocol/ Fri Mar 20 17:25:14 -0700 2009 adding aman's amqp code [famoseagle]
directory test/ Wed Aug 26 12:03:05 -0700 2009 fixed 'unexpected length' exceptions when handl... [famoseagle]
README.markdown

Carrot

A synchronous amqp client. Based on Aman's amqp client:

http://github.com/tmm1/amqp/tree/master

Motivation

This client does not use eventmachine so no background thread necessary. As a result, it is much easier to use from script/console and Passenger. It also solves the problem of buffering messages and ack responses. For more details see this thread.

There is currently no way to prevent buffering using eventmachine. Support for prefetch is still unreliable.

Example

require 'carrot'

q = Carrot.queue('name')
10.times do |num|
  q.publish(num.to_s)
end

puts "Queued #{q.message_count} messages"
puts

while msg = q.pop(:ack => true)
  puts "Popping: #{msg}"
  q.ack
end
Carrot.stop

LICENSE

Copyright (c) 2009 Amos Elliston, Geni.com; Published under The MIT License, see License