public
Description: A synchronous amqp client
Homepage:
Clone URL: git://github.com/famoseagle/carrot.git
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 Mon Oct 19 14:55:12 -0700 2009 Pushing carrot to gemcutter [famoseagle]
file VERSION.yml Wed Aug 26 12:06:47 -0700 2009 Version bump to 0.7.0 [famoseagle]
file carrot.gemspec Mon Oct 19 14:55:12 -0700 2009 Pushing carrot to gemcutter [famoseagle]
directory lib/ Wed Aug 26 12:03:05 -0700 2009 fixed 'unexpected length' exceptions when handl... [famoseagle]
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