Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joekiller/jruby-kafka
https://github.com/joekiller/jruby-kafka
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/joekiller/jruby-kafka
- Owner: joekiller
- License: apache-2.0
- Archived: true
- Created: 2013-09-26T03:01:27.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2016-08-12T12:30:58.000Z (over 8 years ago)
- Last Synced: 2024-10-29T07:23:06.543Z (2 months ago)
- Language: Ruby
- Size: 251 KB
- Stars: 71
- Watchers: 8
- Forks: 52
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-kafka - JRuby
README
# Jruby::Kafka
[![Build Status](https://travis-ci.org/joekiller/jruby-kafka.svg?branch=master)](https://travis-ci.org/joekiller/jruby-kafka)
Version 2.x => Kafka 0.8.2.2
Version 3.x => Kafka 0.9.0.1
Version 4.x => Kafka 0.10.0.1
## Prerequisites
* [JRuby] 1.7.19+ installed.
[Apache Kafka]: http://kafka.apache.org/
[JRuby]: http://jruby.org/## About
This gem is primarily used to wrap most of the [Kafka high level consumer] and [Kafka producer] API into
jruby.
The [Kafka Consumer Group Example] is pretty much ported to this library.- [Kafka 0.8.2.x high level consumer](http://kafka.apache.org/082/documentation.html#highlevelconsumerapi)
- [Kafka 0.8.2.x java producer](http://kafka.apache.org/082/javadoc/index.html?org/apache/kafka/clients/producer/KafkaProducer.html)
- [Kafka 0.8.2.x scala producer](http://kafka.apache.org/082/documentation.html#producerapi)
- [Kafka Consumer Group Example](https://cwiki.apache.org/confluence/display/KAFKA/Consumer+Group+Example)
Note that the Scala `Kafka::Producer` will deprecate and Java `Kafka::KafkaProducer` is taking over.
(The 0.8.2.x and 0.9x consumer/producer APIs are similar)## Installation
This package is now distributed via [RubyGems.org](http://rubygems.org) but you can build it using the following instructions.
From the root of the project run:
$ bundle install
$ rake setup jar packageYou can run the following to install the resulting package:
$ gem install jruby-kafka*.gem
Add this line to your application's Gemfile:
gem 'jruby-kafka', "~> #{your_version_here}" # '~> 2.0.0' for 0.8.2.2 brokers, '~> 3.0.0' for 0.9 brokers
## Usage
If you want to run the tests, make sure you already have downloaded Kafka 0.8.X, followed the [kafka quickstart]
instructions and have KAFKA_PATH set in the environment.[kafka quickstart]: http://kafka.apache.org/documentation.html#quickstart
#### Usage
The following producer code sends a message to a `test` topic.
```ruby
require 'jruby-kafka'producer_options = {:broker_list => "localhost:9092", "serializer.class" => "kafka.serializer.StringEncoder"}
producer = Kafka::Producer.new(producer_options)
producer.connect()
producer.send_msg("test", nil, "here's a test message")
```The following consumer example is the Ruby equivalent of the Kafka high-level consumer group example. It listens for 10 seconds to the `test` topic and prints out messages as they are received from Kafka in two threads. The `test` topic should have at least two partitions for each thread to receive messages.
```ruby
require 'jruby-kafka'consumer_options = {
zookeeper_connect: 'localhost:2181',
group_id: 'my_consumer_group',
topic: 'test',
num_streams: 2,
auto_offset_reset: "smallest"
}consumer = Kafka::Consumer.new(consumer_options)
def consumer_test(stream, thread_num)
it = stream.iterator
puts "Thread #{thread_num}: #{it.next.message.to_s}" while it.hasNext
puts "Shutting down Thread: #{thread_num}"
endstreams = consumer.message_streams
streams.each_with_index do |stream, thread_num|
Thread.new { consumer_test stream, thread_num }
endsleep 10
consumer.shutdown
```## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request