EM-Kafka
EventMachine driver for Kafka.
Producer
When using Ruby objects, the payload is encoded to JSON
producer = EM::Kafka::Producer.new("kafka://topic@localhost:9092/0")
producer.deliver(:foo => "bar") # payload is {foo:"bar"}
Consumer
consumer = EM::Kafka::Consumer.new("kafka://topic@localhost:9092/0")
consumer.consume do ||
puts .payload
end
Messages
Messages are composed of:
- a payload
- a magic id (defaults to 0)
Change the magic id when the payload format changes:
EM::Kafka::Message.new("payload", 2)
Pass messages when you want to be specific:
= EM::Kafka::Message.new("payload_1", 2)
= EM::Kafka::Message.new("payload_2", 2)
producer.deliver([, ])
Credits
Heavily influenced by / borrowed from:
- kafka-rb (Alejandro Crosa)
- em-hiredis (Martyn Loughran)