Bucketer
This is a generic tool for putting arbitrary objects into buckets and setting callbacks to be called when any bucket exceeds a specific threshold size. The interface is intentially written using blocks/callbacks as it is suited for use in EventMachine code.
Currently an in memory bucketer is supported, however it is intended that a redis backed bucketer will be added later and it will be using em-hiredis gem for redis interaction and it will actually be asynchronous.
Installation
Add this line to your application's Gemfile:
gem 'bucketer'
And then execute:
$ bundle
Or install it yourself as:
$ gem install bucketer
Usage
bucketer = Bucketer::InMemory.new(:bucket_threshold_size => 5)
bucketer.on_bucket_full do |bucket_id|
p "yay bucket #{bucket_id} filled up!"
end
bucketer.add_item("1", "1", {:foo => :bar})
bucketer.add_item("1", "2", {:foo => :bar})
bucketer.add_item("1", "3", {:foo => :bar})
bucketer.add_item("1", "4", {:bar => :foo})
bucketer.add_item("1", "5", {:bar => :foo})
Contributing
- Fork it ( https://github.com/dgvz/bucketer/fork )
- Create your feature branch (
git checkout -b my-new-feature) - Commit your changes (
git commit -am 'Add some feature') - Push to the branch (
git push origin my-new-feature) - Create a new Pull Request