Stretcher
A concise, fast ElasticSearch Ruby client designed to reflect the actual elastic search API as closely as possible. Elastic search's API is complex, and mostly documented on the Elastic Search Guide. This client tries to stay out of your way more than others making advanced techniques easier to implement, and making debugging Elastic Search's sometimes cryptic errors easier. Stretcher is currently in production use by Pose, Get Satisfaction, Reverb, and many others.
Features
- Cleanly matches up to elastic search's JSON api
- Efficiently re-uses connections on a per-server object basis (via excon)
- Supports efficient bulk indexing operations
- Returns most responses in convenient Hashie::Mash form
- Configurable logging
- Logs curl commandline statements in debug mode
- Pure, threadsafe, ruby
- Easily swap HTTP clients via Faraday
- Tested against Ruby 2.0,1.9, Jruby, and Rubinius
- Semantically versioned
Installation
Add this line to your application's Gemfile:
gem 'stretcher'
Usage
Getting Started
- Basic Usage
- Multi Search
- Bulk Indexing
- Percolate
- Logging
- Rails Integration
RDocs
Stretcher Strives to provide adequate documentation for all methods. Many methods not described in the 'Getting Started' section can be found in the full rdocs.
Basic Usage
server = Stretcher::Server.new('http://localhost:9200')
server.index(:foo).delete rescue nil
server.index(:foo).create(mappings: {tweet: {properties: {text: {type: 'string'}}}})
30.times {|t| server.index(:foo).type(:tweet).put(t, {text: "Hello #{t}"}) }
server.index(:foo).type(:tweet).get(3)
res = server.index(:foo).search(size: 12, query: {match_all: {}})
res.class
res.total
res.documents
res.facets
res.raw
res.raw_plain
alias = server.index(:foo).alias(:my_alias)
alias.create({ filter: { term: { user_id: 1 } } })
alias.index_context.search({ query: { match_all: {} } })
server.cluster.health
Block Syntax
Stretcher::Server.with_server('http://localhost:9200') {|srv|
srv.index(:foo) {|idx|
idx.type(:tweet) {|t| {exists: t.exists?, mapping: t.get_mapping} }
}
}
Multi Search
server.index(:foo).msearch([{query: {match_all: {}}}])
server.msearch([{index: :foo}, {query: {match_all: {}}}])
Bulk Indexing
docs = [{"_type" => "tweet", "_id" => 91011, "text" => "Bulked"}]
server.index(:foo).bulk_index(docs)
Percolate
Implements the ElasticSearch Percolate API
server.index(:foo).register_percolator_query(query_name, query_hash)
server.index(:foo).type(:foo1).percolate(doc)
server.index(:foo).delete_percolator_query(query_name)
Logging
Pass in the :log_level
parameter to set logging verbosity. cURL statements are surfaced at the :debug
log level. For instance:
Stretcher::Server.new('http://localhost:9200', :log_level => :debug)
You can also pass any Logger style object with the :logger
option. For instance:
Stretcher::Server.new('http://localhost:9200', :logger => Rails.logger)
Rails Integration
Stretcher is a low level-client, but it was built as a part of a full suite of Rails integration tools.
While not yet open-sourced, you can read our detailed blog post: integrating Stretcher with Rails.
Running Specs
Running the specs requires an operational Elastic Search server on http://localhost:9200.
The test suite is not to be trusted, don't count on your indexes staying around!
Specs may be run with rake spec
Email or tweet @andrewvc if you'd like to be added to this list!
Contributors
Contributing
- Fork it
- 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 new Pull Request