* Added client helpers * Updated test * The search helper should return only the documents * Added code comments * Fixed bug * Updated test * Removed bulkSize and added flushBytes * Updated test * Added concurrency * Updated test * Added support for 429 handling in the scroll search helper * Updated test * Updated stats count * Updated test * Fix test * Use client maxRetries as default * Updated type definitions * Refactored bulk helper to be more consistent with the client api * Updated test * Improved error handling, added refreshOnCompletion option and forward additinal options to the bulk api * Updated type definitions * Updated test * Fixed test on Node v8 * Updated test * Added TODO * Updated docs * Added Node v8 note * Updated scripts * Removed useless files * Added helpers to integration test * Fix cli argument position * Moar fixes * Test run elasticsearch in github actions * Use master action version * Add vm.max_map_count step * Test new action setup * Added Configure sysctl limits step * Updated action to latest version * Don't run helpers integration test in jenkins * Run helpers integratino test also with Node v10 * Updated docs * Updated docs * Updated helpers type definitions * Added test for helpers type definitions * Added license header
198 lines
7.1 KiB
Markdown
198 lines
7.1 KiB
Markdown
<img align="right" width="auto" height="auto" src="https://www.elastic.co/static-res/images/elastic-logo-200.png">
|
||
|
||
# Elasticsearch Node.js client
|
||
|
||
[](http://standardjs.com/) [](https://clients-ci.elastic.co/view/Javascript/job/elastic+elasticsearch-js+master/) [](https://codecov.io/gh/elastic/elasticsearch-js) [](https://www.npmjs.com/package/@elastic/elasticsearch)
|
||
|
||
The official Node.js client for Elasticsearch.
|
||
|
||
---
|
||
|
||
**Note:** In the past months we have worked on the new Elasticsearch Node.js client and you can use it by following the instructions below. If you're going to use the legacy one or report an issue, however, please check out [elastic/elasticsearch-js-legacy](https://github.com/elastic/elasticsearch-js-legacy).
|
||
|
||
---
|
||
|
||
## Features
|
||
- One-to-one mapping with REST API.
|
||
- Generalized, pluggable architecture.
|
||
- Configurable, automatic discovery of cluster nodes.
|
||
- Persistent, Keep-Alive connections.
|
||
- Load balancing across all available nodes.
|
||
- Child client support.
|
||
- TypeScript support out of the box.
|
||
|
||
## Install
|
||
```
|
||
npm install @elastic/elasticsearch
|
||
```
|
||
|
||
### Compatibility
|
||
|
||
The minimum supported version of Node.js is `v8`.
|
||
|
||
The library is compatible with all Elasticsearch versions since 5.x, and you should use the same major version of the Elasticsearch instance that you are using.
|
||
|
||
| Elasticsearch Version | Client Version |
|
||
| --------------------- |----------------|
|
||
| `master` | `master` |
|
||
| `7.x` | `7.x` |
|
||
| `6.x` | `6.x` |
|
||
| `5.x` | `5.x` |
|
||
|
||
To install a specific major of the client, run the following command:
|
||
```
|
||
npm install @elastic/elasticsearch@<major>
|
||
```
|
||
|
||
#### Browser
|
||
|
||
WARNING: There is no official support for the browser environment. It exposes your Elasticsearch instance to everyone, which could lead to security issues.
|
||
We recommend that you write a lightweight proxy that uses this client instead.
|
||
|
||
## Documentation
|
||
|
||
- [Introduction](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/introduction.html)
|
||
- [Usage](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/client-usage.html)
|
||
- [Client configuration](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/client-configuration.html)
|
||
- [API reference](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/api-reference.html)
|
||
- [Breaking changes coming from the old client](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/breaking-changes.html)
|
||
- [Authentication](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/auth-reference.html)
|
||
- [Observability](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/observability.html)
|
||
- [Creating a child client](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/child-client.html)
|
||
- [Extend the client](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/extend-client.html)
|
||
- [Client helpers](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/client-helpers.html)
|
||
- [Typescript support](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/typescript.html)
|
||
- [Examples](https://www.elastic.co/guide/en/elasticsearch/client/javascript-api/current/examples.html)
|
||
|
||
## Quick start
|
||
|
||
First of all, require the client and initialize it:
|
||
```js
|
||
const { Client } = require('@elastic/elasticsearch')
|
||
const client = new Client({ node: 'http://localhost:9200' })
|
||
```
|
||
|
||
You can use both the callback-style API and the promise-style API, both behave the same way.
|
||
```js
|
||
// promise API
|
||
const result = await client.search({
|
||
index: 'my-index',
|
||
body: { foo: 'bar' }
|
||
})
|
||
|
||
// callback API
|
||
client.search({
|
||
index: 'my-index',
|
||
body: { foo: 'bar' }
|
||
}, (err, result) => {
|
||
if (err) console.log(err)
|
||
})
|
||
```
|
||
The returned value of **every** API call is formed as follows:
|
||
```ts
|
||
{
|
||
body: object | boolean
|
||
statusCode: number
|
||
headers: object
|
||
warnings: [string]
|
||
meta: object
|
||
}
|
||
```
|
||
|
||
Let's see a complete example!
|
||
```js
|
||
'use strict'
|
||
|
||
const { Client } = require('@elastic/elasticsearch')
|
||
const client = new Client({ node: 'http://localhost:9200' })
|
||
|
||
async function run () {
|
||
// Let's start by indexing some data
|
||
await client.index({
|
||
index: 'game-of-thrones',
|
||
// type: '_doc', // uncomment this line if you are using Elasticsearch ≤ 6
|
||
body: {
|
||
character: 'Ned Stark',
|
||
quote: 'Winter is coming.'
|
||
}
|
||
})
|
||
|
||
await client.index({
|
||
index: 'game-of-thrones',
|
||
// type: '_doc', // uncomment this line if you are using Elasticsearch ≤ 6
|
||
body: {
|
||
character: 'Daenerys Targaryen',
|
||
quote: 'I am the blood of the dragon.'
|
||
}
|
||
})
|
||
|
||
await client.index({
|
||
index: 'game-of-thrones',
|
||
// type: '_doc', // uncomment this line if you are using Elasticsearch ≤ 6
|
||
body: {
|
||
character: 'Tyrion Lannister',
|
||
quote: 'A mind needs books like a sword needs a whetstone.'
|
||
}
|
||
})
|
||
|
||
// here we are forcing an index refresh, otherwise we will not
|
||
// get any result in the consequent search
|
||
await client.indices.refresh({ index: 'game-of-thrones' })
|
||
|
||
// Let's search!
|
||
const { body } = await client.search({
|
||
index: 'game-of-thrones',
|
||
// type: '_doc', // uncomment this line if you are using Elasticsearch ≤ 6
|
||
body: {
|
||
query: {
|
||
match: { quote: 'winter' }
|
||
}
|
||
}
|
||
})
|
||
|
||
console.log(body.hits.hits)
|
||
}
|
||
|
||
run().catch(console.log)
|
||
```
|
||
|
||
## Install multiple versions
|
||
If you are using multiple versions of Elasticsearch, you need to use multiple versions of the client. In the past, install multiple versions of the same package was not possible, but with `npm v6.9`, you can do that via aliasing.
|
||
|
||
The command you must run to install different version of the client is:
|
||
```sh
|
||
npm install <alias>@npm:@elastic/elasticsearch@<version>
|
||
```
|
||
So for example if you need to install `7.x` and `6.x`, you will run
|
||
```sh
|
||
npm install es6@npm:@elastic/elasticsearch@6
|
||
npm install es7@npm:@elastic/elasticsearch@7
|
||
```
|
||
And your `package.json` will look like the following:
|
||
```json
|
||
"dependencies": {
|
||
"es6": "npm:@elastic/elasticsearch@^6.7.0",
|
||
"es7": "npm:@elastic/elasticsearch@^7.0.0"
|
||
}
|
||
```
|
||
You will require the packages from your code by using the alias you have defined.
|
||
```js
|
||
const { Client: Client6 } = require('es6')
|
||
const { Client: Client7 } = require('es7')
|
||
|
||
const client6 = new Client6({ node: 'http://localhost:9200' })
|
||
const client7 = new Client7({ node: 'http://localhost:9201' })
|
||
|
||
client6.info(console.log)
|
||
client7.info(console.log)
|
||
```
|
||
|
||
Finally, if you want to install the client for the next version of Elasticsearch *(the one that lives in Elasticsearch’s master branch)*, you can use the following command:
|
||
```sh
|
||
npm install esmaster@github:elastic/elasticsearch-js
|
||
```
|
||
|
||
## License
|
||
|
||
This software is licensed under the [Apache 2 license](./LICENSE).
|