Pulls documents from Elasticsearch according to the query specified by the user and converts each document to a Structured Record with the fields and schema specified by the user. The Elasticsearch server should be running prior to creating the application.

This source is used whenever you need to read data from Elasticsearch. For example, you may want to read in an index and type from Elasticsearch and store the data in an HBase table.


referenceName: This will be used to uniquely identify this source for lineage, annotating metadata, etc.

es.host: The hostname and port for the Elasticsearch instance. (Macro-enabled)

es.index: The name of the index to query. (Macro-enabled)

es.type: The name of the type where the data is stored. (Macro-enabled)

query: The query to use to import data from the specified index and type; see Elasticsearch for additional query examples. (Macro-enabled)

schema: The schema or mapping of the data in Elasticsearch.


This example connects to Elasticsearch, which is running locally, and reads in records in the specified index (megacorp) and type (employee) which match the query to (in this case) select all records. All data from the index will be read on each run:

    "name": "Elasticsearch",
    "type": "batchsource",
    "properties": {
        "es.host": "localhost:9200",
        "es.index": "megacorp",
        "es.type": "employee",
        "query": "?q=*",
        "schema": "{

  • CDAP Pipelines Plugin Type: batchsource
  • CDAP Pipelines Version: 1.6.2-SNAPSHOT