Skip to content

elastic/elasticsearch-serverless-ruby

Elasticsearch Serverless Client

main Build status

This is the official Elastic client for Elasticsearch Cloud Serverless.

If you're looking to develop your Ruby application with the Elasticsearch Stack, you should look at the Elasticsearch Client instead.

Guide

You need to have Ruby version 3.0 or higher installed to use this gem. We follow Ruby’s own maintenance policy and officially support all currently maintained versions per Ruby Maintenance Branches.

You can install the Elasticsearch Serverless Ruby Client from RubyGems:

$ gem install elasticsearch-serverless

Or include it in your Ruby project's Gemfile:

gem 'elasticsearch-serverless'

Once installed, require it in your code:

require 'elasticsearch-serverless'

Additionally, you can find a rake task in the project's code to run a Ruby console with the required librares to use the client loaded into it:

$ bundle exec rake console

rake console

Instantiate a Client

You need to be using the Elastiscearch Serverless service in order to use the elasticsearch-serverless gem. You will need your deployment's endpoint for Elasticsearch and an API key.

In your Elasticsearch Serverless Cloud deployment home page, create an API Key and copy the generated code:

Copy the endpoint and API Key code for Elasticsearch

You can now instantiate a client with the values you got:

client = ElasticsearchServerless::Client.new(
  api_key: 'your_api_key',
  url: 'https://my-deployment-url'
)

Configuration

Elasticsearch Serverless Ruby uses elastic-transport as the HTTP layer to connect to Elasticsearch Serverless. You can use some of the following parameters when instatiating a client in the arguments hash like so:

client = ElasticsearchServerless::Client.new(
  api_key: 'API_KEY',
  url: 'URL',
  arguments: {
    adapter: :net_http_persistent,
    log: true,
    logger: MyLogger.new
  }
)

The parameters are:

Key Type Description
adapter string A specific adapter for Faraday (patron, typhoeus, HTTPClient, NetHttpPersistent).
log boolean Log requests and responses to standard output with the default logger (an instance of Ruby’s ::Logger class), disabled by default.
logger Logger An instance of a Logger-compatible object to use as a logger.
trace boolean Use the default tracer to trace requests and responses in the Curl format.
tracer Logger An instance of a Logger-compatible object to use as a tracer.
serializer_class Object A specific serializer class to use to serialize JSON.
headers Hash Custom HTTP Request Headers

Using the API

See APIs for the full list of available endpoints. Check rubydoc for the API reference, or run yardoc or rake doc in the root directory of the project if you've checked out the code. The API reference documentation will be generated in the doc folder.

Once you've instantiated a client with your API key and Elasticsearch endpoint, you can start ingesting documents into Elasticsearch Service. You can use the Bulk API for this. This API allows you to index, update and delete several documents in one request. You call the bulk API on the client with a body parameter, an Array of hashes that define the action and a document. Here's an example of indexing some classic books into the books index:

# First we build our data:
documents = [
  { index: { _index: 'books', data: {name: "Snow Crash", author: "Neal Stephenson", release_date: "1992-06-01", page_count: 470} } },
  { index: { _index: 'books', data: {name: "Revelation Space", author: "Alastair Reynolds", release_date: "2000-03-15", page_count: 585} } },
  { index: { _index: 'books', data: {name: "1984", author: "George Orwell", release_date: "1949-06-08", page_count: 328} } },
  { index: { _index: 'books', data: {name: "Fahrenheit 451", author: "Ray Bradbury", release_date: "1953-10-15", page_count: 227} } },
  { index: { _index: 'books', data: {name: "Brave New World", author: "Aldous Huxley", release_date: "1932-06-01", page_count: 268} } },
  { index: { _index: 'books', data: {name: "The Handmaid's Tale", author: "Margaret Atwood", release_date: "1985-06-01", page_count: 311} } }
]
# Then we send the data via the bulk api:
> response = client.bulk(body: documents)
# And we can check that the items were indexed and given an id in the response:
> response['items']
 =>
[{"index"=>{"_index"=>"books", "_id"=>"Pdink4cBmDx329iqhzM2", "_version"=>1, "result"=>"created", "_shards"=>{"total"=>2, "successful"=>1, "failed"=>0}, "_seq_no"=>0, "_primary_term"=>1, "status"=>201}},
 {"index"=>{"_index"=>"books", "_id"=>"Ptink4cBmDx329iqhzM2", "_version"=>1, "result"=>"created", "_shards"=>{"total"=>2, "successful"=>1, "failed"=>0}, "_seq_no"=>1, "_primary_term"=>1, "status"=>201}},
 {"index"=>{"_index"=>"books", "_id"=>"P9ink4cBmDx329iqhzM2", "_version"=>1, "result"=>"created", "_shards"=>{"total"=>2, "successful"=>1, "failed"=>0}, "_seq_no"=>2, "_primary_term"=>1, "status"=>201}},
 {"index"=>{"_index"=>"books", "_id"=>"QNink4cBmDx329iqhzM2", "_version"=>1, "result"=>"created", "_shards"=>{"total"=>2, "successful"=>1, "failed"=>0}, "_seq_no"=>3, "_primary_term"=>1, "status"=>201}},
 {"index"=>{"_index"=>"books", "_id"=>"Qdink4cBmDx329iqhzM2", "_version"=>1, "result"=>"created", "_shards"=>{"total"=>2, "successful"=>1, "failed"=>0}, "_seq_no"=>4, "_primary_term"=>1, "status"=>201}},
 {"index"=>{"_index"=>"books", "_id"=>"Qtink4cBmDx329iqhzM2", "_version"=>1, "result"=>"created", "_shards"=>{"total"=>2, "successful"=>1, "failed"=>0}, "_seq_no"=>5, "_primary_term"=>1, "status"=>201}}]

When you use the client to make a request to Elasticsearch, it will return an API Response object. You can see the HTTP return code by calling status and the HTTP headers by calling headers on the response object. The Response object behaves as a Hash too, so you can access the body values directly as seen on the previous example with response['items'].

You can call the update API to update a document:

response = client.update(
  index: 'books',
  id: 'document_id',
  body: { doc: { page_count: 312 } }
)

You can call the delete API to delete a document:

client.delete(index: 'books', id: 'Ptink4cBmDx329iqhzM2')

Now that some data is available, you can search your documents using the Search API:

> response = client.search(index: 'books', q: 'snow')
> response['hits']['hits']
 => [{"_index"=>"books", "_id"=>"Pdink4cBmDx329iqhzM2", "_score"=>1.5904956, "_source"=>{"name"=>"Snow Crash", "author"=>"Neal Stephenson", "release_date"=>"1992-06-01", "page_count"=>470}}]

Using OpenTelemetry

The Client comes with built-in OpenTelemetry instrumentation that emits distributed tracing spans by default. You can find out how to use it in the official documentation. The only difference from the Elasticsearch Stack Client is how to pass in a tracer provider when instantiating the client. In Elasticsearch Serverless, you need to use the following code:

client = ElasticsearchServerless::Client.new(
  api_key: 'your_api_key',
  url: 'https://my-deployment-url',
  arguments: { opentelemetry_tracer_provider: tracer_provider }
)

Development

See CONTRIBUTING.

About

Elasticsearch Serverless Ruby Client

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages