The official Java client for Elasticsearch.
The Java client for Elasticsearch provides strongly typed requests and responses for all Elasticsearch APIs. It delegates protocol handling to an http client such as the Elasticsearch Low Level REST client that takes care of all transport-level concerns (http connection establishment and pooling, retries, etc).
The docs/design
folder contains records of the major decisions in the design of the API. Most notably:
- Object construction is based on the builder pattern.
- Nested objects can be constructed with builder lambdas, allowing for clean and expressive DSL-like code.
- Optional values are represented as
null
with@Nullable
annotations instead of the newerOptional
, the Java ecosystem being still very null-based.
Download the latest version of Elasticsearch or sign-up for a free trial of Elastic Cloud.
Refer to the Installation section of the getting started documentation.
Refer to the Connecting section of the getting started documentation.
- Creating an index
- Indexing a document
- Getting documents
- Searching documents
- Updating documents
- Deleting documents
- Deleting an index
Please refer to the full documentation on elastic.co for comprehensive information.
See CONTRIBUTING.md
This software is licensed under the Apache License 2.0.