Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mallocator/Elasticsearch-Exporter
A small script to export data from one Elasticsearch cluster into another.
https://github.com/mallocator/Elasticsearch-Exporter
Last synced: 26 days ago
JSON representation
A small script to export data from one Elasticsearch cluster into another.
- Host: GitHub
- URL: https://github.com/mallocator/Elasticsearch-Exporter
- Owner: mallocator
- License: apache-2.0
- Archived: true
- Created: 2012-08-13T12:46:18.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2024-01-18T03:17:16.000Z (11 months ago)
- Last Synced: 2024-10-29T01:10:54.012Z (about 2 months ago)
- Language: JavaScript
- Size: 565 KB
- Stars: 593
- Watchers: 43
- Forks: 112
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-elasticsearch - Elasticsearch-Exporter
- elasticsearch-collection - Elasticsearch-Exporter
README
# Elasticsearch-Exporter
[![npm version](https://badge.fury.io/js/elasticsearch-exporter.svg)](http://badge.fury.io/js/elasticsearch-exporter)
[![Build Status](https://travis-ci.org/mallocator/Elasticsearch-Exporter.svg?branch=master)](https://travis-ci.org/mallocator/Elasticsearch-Exporter)
[![Coverage Status](https://coveralls.io/repos/mallocator/Elasticsearch-Exporter/badge.svg?branch=master&service=github)](https://coveralls.io/github/mallocator/Elasticsearch-Exporter?branch=master)
[![Dependency Status](https://david-dm.org/mallocator/Elasticsearch-Exporter.svg)](https://david-dm.org/mallocator/Elasticsearch-Exporter)# This project is no longer maintained!
Sorry for anyone looking for an exporter from ElasticSearch, but I've moved on to other projects. This code hasn't been updated in years and is way behind the
latest versions of ElasticSearch. The last compatible version was probably v5. If there is any other project that meets this requirement I'd be happy to
link it here (message me), otherwise, you'll have to search for a different solution.Thank you to all the contributors, whether it was bug reports, ideas, or CRs. I appreciate the feedback I got from the community for this project and hope to
contribute more in the future, if not in this project then in others. Take care!## About
A command line script to import/export data from ElasticSearch to various other storage systems.
Features:
* Node.js-based command line tool
* Export to another ElasticSearch instance, compressed flat files, MySQL, Mongo DB, etc.
* Recreates mapping and settings on the target
* Source data and metadata can be filtered by query
* Specify scope as type, index, or whole cluster
* Run in test mode without modifying any data
* Support for proxies, authentication, and SSL
* Works with most ElasticSearch versions
* Run multiple requests in separate processes in parallel## Version 2
This is a newer implementation with lots of bugs and way too little time to test everything for one lonely developer, so please consider this __beta__ at
best and provide feedback, bug reports, and maybe even patches.This version will not be released to npm until it's been a little more tested out in the wild. Once it is available consider double-checking your package
declarations as this version is not backward compatible with the 1.x branch.## Usage
The exporter uses a number of drivers to import and export data and uses a plugin-based system that lets developers extend the existing drivers with their own.
The script has an extensive description of all options for each driver which are shown when the script is run without any parameters. Per default, only the
options for the ElasticSearch driver are shown. To see what options a particular driver offers either choose the driver as source or target driver on the
command line:
```
node exporter.js -s file -t mongodb
```
The options shown will be specific to the respective source or target driver. All source options are prefixed with 's' and all target options are prefixed
with 't'. Here are some examples of how to use the script. The script is trying to be smart enough to guess all missing options, so that e.g. if you don't
specify a target type, but a target index, the type will be copied over without any changes. If you find that any combination of configurations doesn't make
sense, please file a bug on [Github](https://github.com/mallocator/Elasticsearch-Exporter/issues).
```JavaScript
// copy all indices from machine a to b
node exporter.js -a localhost -b foreignhost// copy entire index1 to index2 on same machine
node exporter.js -si index1 -ti index2// copy type1 to type2 in same index
node exporter.js -si index -st type1 -tt type2// copy type1 from index1 to type2 in index2
node exporter.js -si index1 -st type1 -ti index2 -tt type2// copy entire index1 from machine a to b
node exporter.js -sh localhost -si index1 -th foreignhost// copy index1 from machine1 to index2 on machine2
node exporter.js -sh localhost -si index1 -th foreignhost -ti index2// only copy stuff from machine1 to machine2, that is in the query
node exporter.js -sh localhost -th foreignhost -sq '{"bool":{"must":{"term":{"field1":"value1"}}}}'// do not execute any operation on machine2, just see the amount of data that would be queried
node exporter.js -sh localhost -th foreignhost -r true// use basic authentication for source and target connection
node exporter.js -sh localhost -sa myuser:mypass -th foreignhost -ta myuser:mypass
```From database to file or vice versa you can use the following commands. Note that data files are now stored in a directory structure.
```JavaScript
// Export to file from database
node exporter.js -sh localhost -si index1 -st type1 -t file -tf filename// Import from file to database
node exporter.js -s file -sf filename -th foreignhost -ti index2 -tt type2```
You also read all configuration from a file. The properties of the json read match one to one the extended option names shown in the help output.
```JavaScript
// use an options file for configuration
node exporter.js -o myconfig.json//myconfig.json
{
"drivers": {
"source": "elasticsearch-query",
"target": "mysql"
},
"source": {
"host" : "localhost",
"index" : "myindex"
},
"target": {
"host" : "foreignhost"
}
}
```If memory is an issue pass these parameters and the process will try to run garbage collection before reaching memory limitations
```
node --nouse-idle-notification --expose-gc exporter.js ...
```Or make use of the script in the tools folder:
```
tools/ex.sh ...
```## Drivers
The script comes with a few drivers readily available that can be used as a source or target. While it is possible to use non-ElasticSearch drivers for both
source and target, be advised that support for full transfers is usually limited so that e.g. a copy from MySQL to MySQL will probably include some transformation
of the data to accommodate for the ElasticSearch format which is used as representation internally.To get a list of all active drivers run either ```node exporter.js -l``` or ```node exporter.js -ll```.
### ElasticSearch Scroll Driver (id: elasticsearch) (default)
This driver uses the scroll API to fetch data from an ElasticSearch cluster. It's activated by default and offers the old functionality that has been
available with the exporter v1.x. As an alternative you can try the query-based driver which supports multi-threading for higher performance.### ElasticSearch Query Driver (id: elasticsearch-query)
This driver uses the query API to fetch data from ElasticSearch. Other than that all calls are the same and inserts are done using the same bulk mechanism
as the default driver. Note though that behaviour on a cluster that is changing state (documents are being inserted/updated) has not been tested. I would not be
surprised if the order between fetch requests of a match_all can change and documents are omitted.### Elasticsearch Client Driver (id: elasticsearch-client)
This driver makes use of the elasticsearch.js client to connect to the database and supports version 5.0 of Elasticsearch. The driver is experimental for now but will
eventually replace the standard driver once it's proven to be stable. Note that some options such as defining a proxy and checking cluster CPU usage are not available
(yet?).### File Driver (id: file)
This driver has also been ported from the previous version and allows to store data on the local file system. Different than the previous version this driver now
stores data in a directory structure (uncompressed). This allows us to do more complex operations on top of the existing file data, such as partial imports.### CSV Driver (id: csv)
The CSV driver for now only supports exporting to file, not importing from file. The CSV file will have the root properties of all indices/types specified, without
distinguishing between them. Nested properties/values will be stored as stringified JSON. The plugin will adhere to CSV standards but several options can be set
to override that behavior.### MySQL Driver (id: mysql)
tbd.### SQLite Driver (id: sqlite)
tbd.### MongoDB Driver (id: mongodb)
tbd.### HBase Driver (id: hbase)
tbd.### Google BigQuery Driver (id: bigquery)
tbd.
This driver will import data from a BigQuery dataset using Google ServiceAccounts. To access your project you need to have a ServiceAccount available with the
user and the authorizing key (in pem format). The driver supports mapping columns into more complex objects through the transformation option. A sample configuration
would look like this:
```
{
_id: 'the id column name in bigquery',
object1: {
property1: 'the property column name in bigquery'
}
}
```### AppEngine Datastore Driver (id: datastore)
tbd.## Requirements
To run this script you will need at least node v0.10. All required dependencies will be installed using npm.
## Installation
Run the following command in the directory where you want the tools installed
npm install elasticsearch-exporter --production
The required packages will be installed automatically as a dependency, you won't have to do anything else to use the tool. If you install the package with the
global flag (```npm -g```) there will also be a new executable available in the system called "eexport".Notice that if you don't install released versions from npm and use the master instead, that it is in active development and might not be working. For help and
questions you can always [file an issue](https://github.com/mallocator/Elasticsearch-Exporter/issues).## Improving Performance
If you're trying to export a large amount of data it can take quite a while to export that data. Here are some tips that might help you speed up the process.
### Reduce Network Hops
In most cases the limiting resource when running the exporter has not been CPU or Memory, but Network IO and response time from ElasticSearch. In some cases it
is possible to speed up the process by reducing network hops. The closer you can get to either the source or target database the better. Try running on one of
the nodes to reduce latency. If you're running a larger cluster try to run the script on the node where most shards of the data are available. This will further
prevent ElasticSearch from making internal hops.### Increase Process Memory
In some cases, the number of requests queue up filling up memory. When running with garbage collection enabled, the client will wait until memory has been freed
if it should fill up, but this might also cause the entire process to take longer to finish. Instead, you can try and increase the amount of memory that the node
process has available. To set memory to a higher value just pass this option with your desired memory setting to the node executable: `--max-old-space-size=600`.
Note that there is an upper limit to the amount a node process can receive, so at some point it doesn't make much sense to increase it any further.### Increase Concurrent Request limit
It might be the case that your network connection can handle a lot more than is typical and that the script is spending the most time waiting for additional
sockets to be free. To get around this you can increase the maximum number of sockets on the global HTTP agent by using the option flag for it
(`--source.maxSockets`). Increase this to see if it will improve anything.### Split up into multiple Jobs
It might be possible to run the script multiple times in parallel. Since the exporter is single-threaded it will only make use of one core and performance can
be gained by querying ElasticSearch multiple times in parallel. To do so simply run the exporter tool against individual types or indexes instead of the entire
cluster. If the bulk of your data is contained in one type make use of the query parameter to further partition the existing data. Since it is necessary to understand
the structure of the existing data it is not planned the exporter will attempt to do any of the optimization automatically.### Export to file first
Sometimes the whole pipe from source to target cluster is simply slow, unstable, and annoying. In such a case try to export to a local file first. This way you
have a complete backup with all the data and can transfer this to the target machine. While this might overall take more time, it might increase the speed of the
individual steps.### Change the fetching size
It might help if you change the size of each scan request that fetches data. The current default of the option `--source.size` is set to 10. Increasing or decreasing
this value might have a great performance impact on the actual export.### CPU throttling
For servers in production, the additional export process can be a strain on the system and degrade response times. To counter this you can set a CPU limit over which
the exporter will back off and wait for the cluster to cool down. The script will not go over the set percentage and wait in incrementing intervals of up to 30
seconds for the cluster to be available again. To enable this feature on the elasticsearch driver just make use of the `--source.cpuLimit` or `--target.cpuLimit`
flags.### Disable replication
The default setting for any index to create 1 replica for each shard. While this is generally speaking a good thing, it can be really bad while importing a new index.
To improve performance you can set the number of replicas to 0 until the import is done and then increase the number of replicas. Under the right circumstances, you
might see a tremendous improvement in performance. The number of replicas can either be controlled by setting manual metadata or by using the `--target.replicas` flag### Optimizing the ElasticSearch Cluster
This tool will only run as fast as your cluster can keep up. If the nodes are under heavy load, errors can occur and the entire process will take longer. How to
optimize your Cluster is a whole other chapter and depends on the version of ElasticSearch that you're running. Try the official documentation, google, or the
ElasticSearch mailing groups for help. The topic is too complex for us to cover here.## Developing your own drivers
The exporter uses a pluggable system for all drivers so that it can be extended and make use of more drivers supplied by the community. If you want to use a
custom driver point the exporter to the directory it resides in using ```node exporter.js -d ```. Note that drivers need to end with the
extension .driver.js to be recognized as a driver for the exporter.When a driver is loaded the exporter will verify if the module signature is correct by scanning for required functions and their parameters. To keep things
in a unified format all parameters need to be named as specified by the exporter. You can add additional parameters for internal use to any function but, the
minimum set of parameters needs to be there.For a more detailed example take a look at [driver.interface.js](drivers/driver.interface.js). All required functions are described there, the file is purely
for documentation purposes. It also showcases some of the data formats that are passed between the core and the drivers. For all formats assume that ElasticSearch
is used as a reference.If your driver needs to store data that is not available in the standard ElasticSearch format, make use of the
[_meta](http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/mapping-meta.html) field.For more detailed help check out the [developers guide](CONTRIBUTING.md)
## Tests
To run the tests you must install the development dependencies along with the production dependencies
npm install elasticsearch-exporter
After that, you can just run ```npm test``` to see an output of all existing tests.
## Bugs and Feature Requests
I try to find all the bugs and have tests to cover all cases, but since I'm working on this project alone, it's easy to miss something.
Also, I'm trying to think of new features to implement, but most of the time I add new features because someone asked me for them.
So please report any bugs or feature requests to [email protected] or file an issue directly on [Github](https://github.com/mallocator/Elasticsearch-Exporter/issues).
Before submitting a bug report specific to your problem, try running the same command and verbose mode `-v` so that I have some additional information to work with.
Thanks!## Donations
Wow, apparently there are people who want to support me. If you're one of them you can do so via bitcoin over here: [mallox@coinbase](https://www.coinbase.com/Mallox)