Important: This documentation is about an older version. It's relevant only to the release noted, many of the features and functions have been updated or replaced. Please view the current version.
Elasticsearch data source
Grafana ships with built-in support for Elasticsearch. You can make many types of queries to visualize logs or metrics stored in Elasticsearch, and annotate graphs with log events stored in Elasticsearch.
This topic explains configuring and querying specific to the Elasticsearch data source. For general documentation on querying data sources in Grafana, see Query and transform data.
For instructions on how to add a data source to Grafana, refer to the administration documentation. Only users with the organization administrator role can add data sources. Administrators can also configure the data source via YAML with Grafana’s provisioning system.
Once you’ve added the Elasticsearch data source, you can configure it so that your Grafana instance’s users can create queries in its query editor when they build dashboards and use Explore.
Supported Elasticsearch versions
This data source supports these versions of Elasticsearch:
- v7.16+
- v8.x
Configure the data source
To configure basic settings for the data source, complete the following steps:
Click Connections in the left-side menu.
Under Your connections, click Data sources.
Enter
Elasticsearch
in the search bar.Click Elasticsearch.
The Settings tab of the data source is displayed.
Set the data source’s basic configuration options:
Name Description Name Sets the name you use to refer to the data source in panels and queries. Default Sets the data source that’s pre-selected for new panels. Url Sets the HTTP protocol, IP, and port of your Elasticsearch server. Access Don’t modify Access. Use Server (default)
or the data source won’t work.
You must also configure settings specific to the Elasticsearch data source. These options are described in the sections below.
Index settings
Use the index settings to specify a default for the time field
and your Elasticsearch index’s name.
You can use a time pattern, such as YYYY.MM.DD
, or a wildcard for the index name.
Configure Min time interval
The Min time interval setting defines a lower limit for the auto group-by time interval.
This value must be formatted as a number followed by a valid time identifier:
Identifier | Description |
---|---|
y | year |
M | month |
w | week |
d | day |
h | hour |
m | minute |
s | second |
ms | millisecond |
We recommend setting this value to match your Elasticsearch write frequency.
For example, set this to 1m
if Elasticsearch writes data every minute.
You can also override this setting in a dashboard panel under its data source options.
X-Pack enabled
Toggle this to enable X-Pack
-specific features and options, which provide the query editor with additional aggregations, such as Rate
and Top Metrics
.
Include frozen indices
When the “X-Pack enabled” setting is active and the configured Elasticsearch version is higher than 6.6.0
, you can configure Grafana to not ignore frozen indices when performing search requests.
Note
Frozen indices are deprecated in Elasticsearch since v7.14.
Logs
You can optionally configure the two Logs parameters Message field name and Level field name to determine which fields the data source uses for log messages and log levels when visualizing logs in Explore.
For example, if you’re using a default setup of Filebeat for shipping logs to Elasticsearch, set:
- Message field name:
message
- Level field name:
fields.level
Data links
Data links create a link from a specified field that can be accessed in Explore’s logs view.
Each data link configuration consists of:
Parameter | Description |
---|---|
Field | Sets the name of the field used by the data link. |
URL/query | Sets the full link URL if the link is external. If the link is internal, this input serves as a query for the target data source. In both cases, you can interpolate the value from the field with the ${__value.raw } macro. |
URL Label | (Optional) Sets a custom display label for the link. The link label defaults to the full external URL or name of the linked internal data source and is overridden by this setting. |
Internal link | Sets whether the link is internal or external. For an internal link, you can select the target data source with a data source selector. This supports only tracing data sources. |
Configure Amazon Elasticsearch Service
If you use Amazon Elasticsearch Service, you can use Grafana’s Elasticsearch data source to visualize data from it.
If you use an AWS Identity and Access Management (IAM) policy to control access to your Amazon Elasticsearch Service domain, you must use AWS Signature Version 4 (AWS SigV4) to sign all requests to that domain.
For details on AWS SigV4, refer to the AWS documentation.
AWS Signature Version 4 authentication
Note
Available in Grafana v7.3 and higher.
To sign requests to your Amazon Elasticsearch Service domain, you can enable SigV4 in Grafana’s configuration.
Once AWS SigV4 is enabled, you can configure it on the Elasticsearch data source configuration page. For more information about AWS authentication options, refer to AWS authentication.
Provision the data source
You can define and configure the data source in YAML files as part of Grafana’s provisioning system. For more information about provisioning, and for available configuration options, refer to Provisioning Grafana.
Note
The previously useddatabase
field has now been deprecated. You should now use theindex
field injsonData
to store the index name. Please see the examples below.
Provisioning examples
Basic provisioning:
apiVersion: 1
datasources:
- name: Elastic
type: elasticsearch
access: proxy
url: http://localhost:9200
jsonData:
index: '[metrics-]YYYY.MM.DD'
interval: Daily
timeField: '@timestamp'
Provision for logs:
apiVersion: 1
datasources:
- name: elasticsearch-v7-filebeat
type: elasticsearch
access: proxy
url: http://localhost:9200
jsonData:
index: '[filebeat-]YYYY.MM.DD'
interval: Daily
timeField: '@timestamp'
logMessageField: message
logLevelField: fields.level
dataLinks:
- datasourceUid: my_jaeger_uid # Target UID needs to be known
field: traceID
url: '$${__value.raw}' # Careful about the double "$$" because of env var expansion
Query the data source
You can select multiple metrics and group by multiple terms or filters when using the Elasticsearch query editor.
For details, see the query editor documentation.
Use template variables
Instead of hard-coding details such as server, application, and sensor names in metric queries, you can use variables. Grafana lists these variables in dropdown select boxes at the top of the dashboard to help you change the data displayed in your dashboard. Grafana refers to such variables as template variables.
For details, see the template variables documentation.