elasticsearch

package module
v0.3.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 30, 2022 License: Apache-2.0 Imports: 1 Imported by: 0

README

Conduit Connector Elasticsearch

General

The Elasticsearch plugin is one of Conduit plugins. It currently provides only destination Elasticsearch connector, allowing for using it as a destination in a Conduit pipeline.

How to build it

Run make.

Destination

The Destination connector stores data in given index. When Record has Key value set, then it is used as a Document ID. Moreover, when Record has action entry in the Metadata, then action specified there is respected. Supported actions:

  • insert when Record.Key is missing: stores a new Document without ID.
  • update: stores or updates (upsert) a Document with ID. Default case when action is not set but Record.Key is set.
  • delete: deletes a Document by its Record.Key.

For any other action a warning entry is added to log and Record is skipped.

Configuration Options

name description required default
version The version of the Elasticsearch service. One of: 5, 6, 7, 8. true
host The Elasticsearch host and port (e.g.: http://127.0.0.1:9200). true
username [v: 5, 6, 7, 8] The username for HTTP Basic Authentication. false
password [v: 5, 6, 7, 8] The password for HTTP Basic Authentication. true when username was provided, false otherwise
cloudId [v: 6, 7, 8] Endpoint for the Elastic Service (https://elastic.co/cloud). false
apiKey [v: 6, 7, 8] Base64-encoded token for authorization; if set, overrides username/password and service token. false
serviceToken [v: 7, 8] Service token for authorization; if set, overrides username/password. false
certificateFingerprint [v: 7, 8] SHA256 hex fingerprint given by Elasticsearch on first launch. false
index The name of the index to write the data to. true
type [v: 5, 6] The name of the index's type to write the data to. true for versions: 5 and 6, false otherwise
bulkSize The number of items stored in bulk in the index. The minimum value is 1, maximum value is 10000. Note that values greater than 1000 may require additional service configuration. true "1000"
retries The maximum number of retries of failed operations. The minimum value is 0 which disabled retry logic. The maximum value is 255. Note that the higher value, the longer it may take to process retries, as a result, ingest next operations. true "1000"

Testing

Run make test to run all the unit and integration tests, which require Docker to be installed and running. The command will handle starting and stopping docker containers for you.

Local development

If you like to monitor Elasticsearch index with visual editor, there is Kibana configuration created for local development that you can run with Elasticsearch Docker container.

docker-compose -f test/docker-compose.v8.overrides.yml -f test/docker-compose.v8.yml -p test-v8 up -d

Don't forget to include it when finishing your work:

docker-compose -f test/docker-compose.v8.overrides.yml -f test/docker-compose.v8.yml down

References

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Specification

func Specification() sdk.Specification

Types

This section is empty.

Directories

Path Synopsis
cmd
internal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL