The Prometheus® exporter plugin for OpenSearch® exposes many OpenSearch metrics in Prometheus format.
- Preface
- Introduction
- Compatibility Matrix
- Install or Remove Plugin
- Plugin Configuration
- Usage
- Build from Source
- Testing
- License
- Trademarks & Attributions
This repository contains two projects that are related, but each can be used independently:
- The first project is a Java plugin – Prometheus Exporter Plugin for OpenSearch® – this code lives in the
main
branch. - The second project is a Jsonnet bundle – OpenSearch® Mixin – this code lives in the
mixin
branch.
This plugin was started as a fork of Prometheus exporter for Elasticsearch® (it was forked in version 7.10.2.0; commit hash: 8dc7f85) utilizing OpenSearch plugin template. It uses the official Prometheus Java Simpleclient.
Currently, the available metrics are:
- Cluster status
- Nodes status:
- JVM
- Indices (global)
- Transport
- HTTP
- Scripts
- Process
- Operating System
- File System
- Circuit Breaker
- Indices status
- Cluster settings (notably disk watermarks that can be updated dynamically)
NOTE: OpenSearch plugins much match exactly in major.minor.path version to the OpenSearch instance it's running in, e.g. plugins versions 2.8.0.x work only with OpenSearch 2.8.0, see also Opensearch Plugins. Therefore you must keep your prometheus-exporter-plugin-for-opensearch version in sync with your OpenSearch version.
OpenSearch | Plugin | Release date |
---|---|---|
2.18.0 | 2.18.0.0 | Jan 03, 2025 |
2.17.1 | 2.17.1.0 | Oct 02, 2024 |
2.17.0 | 2.17.0.0 | Sep 26, 2024 |
2.16.0 | 2.16.0.0 | Aug 08, 2024 |
2.15.0 | 2.15.0.0 | Jun 26, 2024 |
2.14.0 | 2.14.0.0 | May 20, 2024 |
2.13.0 | 2.13.0.0 | Apr 05, 2024 |
2.12.0 | 2.12.0.0 | Feb 27, 2024 |
2.11.1 | 2.11.1.0 | Dec 06, 2023 |
2.11.0 | 2.11.0.0 | Oct 24, 2023 |
2.10.0 | 2.10.0.0 | Sep 27, 2023 |
2.9.0 | 2.9.0.0 | Aug 01, 2023 |
2.8.0 | 2.8.0.0 | Jun 13, 2023 |
2.7.0 | 2.7.0.0 | May 10, 2023 |
2.6.0 | 2.6.0.0 | Mar 03, 2023 |
2.5.0 | 2.5.0.0 | Jan 30, 2023 |
2.4.1 | 2.4.1.0 | Dec 19, 2022 |
2.4.0 | 2.4.0.0 | Nov 18, 2022 |
2.3.0 | 2.3.0.0 | Sep 19, 2022 |
2.2.1 | 2.2.1.0 | Sep 5, 2022 |
2.2.0 | 2.2.0.0 | Aug 13, 2022 |
2.1.0 | 2.1.0.0 | July 13, 2022 |
2.0.1 | 2.0.1.0 | July 12, 2022 |
2.0.0 | 2.0.0.0 | May 27, 2022 |
2.0.0-rc1 | 2.0.0.0-rc1 | May 19, 2022 |
1.3.19 | 1.3.19.0 | Sep 25, 2024 |
1.3.18 | 1.3.18.0 | Sep 25, 2024 |
1.3.17 | 1.3.17.0 | Jun 26, 2024 |
1.3.16 | 1.3.16.0 | May 21, 2024 |
1.3.15 | 1.3.15.0 | Apr 05, 2024 |
1.3.14 | 1.3.14.0 | Dec 20, 2023 |
1.3.13 | 1.3.13.0 | Sep 27, 2023 |
1.3.12 | 1.3.12.0 | Aug 31, 2023 |
1.3.11 | 1.3.11.0 | Jul 06, 2023 |
1.3.10 | 1.3.10.0 | May 23, 2023 |
1.3.9 | 1.3.9.0 | Mar 20, 2023 |
1.3.8 | 1.3.8.0 | Mar 03, 2023 |
1.3.7 | 1.3.7.0 | Dec 19, 2022 |
1.3.6 | 1.3.6.0 | Oct 10, 2022 |
1.3.5 | 1.3.5.0 | Sep 05, 2022 |
1.3.4 | 1.3.4.0 | Jul 15, 2022 |
1.3.3 | 1.3.3.0 | Jun 15, 2022 |
1.3.2 | 1.3.2.0 | May 10, 2022 |
1.3.1 | 1.3.1.0 | Apr 08, 2022 |
1.3.0 | 1.3.0.0 | Mar 22, 2022 |
<= 1.2.4 | (*) | (*) |
(*) If you are looking for plugin releases supporting earlier (<= 1.2.4
) OpenSearch versions please visit
https://github.com/aparo/opensearch-prometheus-exporter/releases.
You need to install the plugin on every OpenSearch node that will be scraped by Prometheus.
To install the plugin:
./bin/opensearch-plugin install https://github.com/aiven/prometheus-exporter-plugin-for-opensearch/releases/download/2.17.1.0/prometheus-exporter-2.17.1.0.zip
To remove the plugin.
./bin/opensearch-plugin remove prometheus-exporter
For more info about plugin CLI, visit: https://opensearch.org/docs/latest/opensearch/install/plugins/
Static settings are configured in config/opensearch.yml
.
All metric names share common prefix, by default set to opensearch_
.
The value of this prefix can be customized using setting:
prometheus.metric_name.prefix: "opensearch_"
Dynamic settings are configured in config/opensearch.yml
but they can also be updated at any time via REST API.
Whether to export detailed index level metrics or not. Default value: true
.
Detailed index level metrics can represent a lot of data and can lead to high-cardinality labels in Prometheus. If you do not need detailed index level metrics it is recommended to disable it via setting:
prometheus.indices: false
Whether to export cluster settings metrics or not. Default value: true
.
To disable exporting cluster settings use:
prometheus.cluster.settings: false
Metrics include statistics about individual OpenSearch nodes. By default, only statistics from the node that received the request are included.
Prometheus exporter can be configured to include statistics from other nodes as well.
This filter is directly utilizing OpenSearch Node filters feature.
Default value: "_local"
.
For example to get stats for all cluster nodes from any node use settings:
prometheus.nodes.filter: "_all"
Prometheus exporter can be configured to filter indices statistics from selected indices.
To target all indices, use "" or * or _all or null.
Default value: ""
.
For example to filter indices statistics:
prometheus.indices_filter.selected_indices: "log-*,*log,*log*,log*-test"
Users can select which option for filtering indices statistics.
Default value: "STRICT_EXPAND_OPEN_FORBID_CLOSED"
.
For example to select an option:
prometheus.indices_filter.selected_option: "LENIENT_EXPAND_OPEN"
Here is a list of indices options available for selection
STRICT_EXPAND_OPEN: indices options that requires every specified index to exist, expands wildcards only to open indices and allows that no indices are resolved from wildcard expressions (not returning an error).
STRICT_EXPAND_OPEN_HIDDEN: indices options that requires every specified index to exist, expands wildcards only to open indices, includes hidden indices, and allows that no indices are resolved from wildcard expressions (not returning an error).
STRICT_EXPAND_OPEN_FORBID_CLOSED: indices options that requires every specified index to exist, expands wildcards only to open indices, allows that no indices are resolved from wildcard expressions (not returning an error) and forbids the use of closed indices by throwing an error.
STRICT_EXPAND_OPEN_HIDDEN_FORBID_CLOSED: indices options that requires every specified index to exist, expands wildcards only to open indices, includes hidden indices, and allows that no indices are resolved from wildcard expressions (not returning an error) and forbids the use of closed indices by throwing an error.
STRICT_EXPAND_OPEN_FORBID_CLOSED_IGNORE_THROTTLED: indices options that requires every specified index to exist, expands wildcards only to open indices, allows that no indices are resolved from wildcard expressions (not returning an error), forbids the use of closed indices by throwing an error and ignores indices that are throttled.
STRICT_EXPAND_OPEN_CLOSED: indices option that requires every specified index to exist, expands wildcards to both open and closed indices and allows that no indices are resolved from wildcard expressions (not returning an error).
STRICT_EXPAND_OPEN_CLOSED_HIDDEN: indices option that requires every specified index to exist, expands wildcards to both open and closed indices, includes hidden indices, and allows that no indices are resolved from wildcard expressions (not returning an error).
STRICT_SINGLE_INDEX_NO_EXPAND_FORBID_CLOSED: indices option that requires each specified index or alias to exist, doesn't expand wildcards and throws error if any of the aliases resolves to multiple indices.
LENIENT_EXPAND_OPEN: indices options that ignores unavailable indices, expands wildcards only to open indices and allows that no indices are resolved from wildcard expressions (not returning an error).
LENIENT_EXPAND_OPEN_HIDDEN: indices options that ignores unavailable indices, expands wildcards to open and hidden indices, and allows that no indices are resolved from wildcard expressions (not returning an error).
LENIENT_EXPAND_OPEN_CLOSED: indices options that ignores unavailable indices, expands wildcards to both open and closed indices and allows that no indices are resolved from wildcard expressions (not returning an error).
LENIENT_EXPAND_OPEN_CLOSED_HIDDEN: indices options that ignores unavailable indices, expands wildcards to all open and closed indices and allows that no indices are resolved from wildcard expressions (not returning an error).
Metrics are directly available at:
http(s)://<opensearch-host>:9200/_prometheus/metrics
As a sample result, you get:
# HELP opensearch_process_mem_total_virtual_bytes Memory used by ES process
# TYPE opensearch_process_mem_total_virtual_bytes gauge
opensearch_process_mem_total_virtual_bytes{cluster="develop",node="develop01",} 3.626733568E9
# HELP opensearch_indices_indexing_is_throttled_bool Is indexing throttling ?
# TYPE opensearch_indices_indexing_is_throttled_bool gauge
opensearch_indices_indexing_is_throttled_bool{cluster="develop",node="develop01",} 0.0
# HELP opensearch_jvm_gc_collection_time_seconds Time spent for GC collections
# TYPE opensearch_jvm_gc_collection_time_seconds counter
opensearch_jvm_gc_collection_time_seconds{cluster="develop",node="develop01",gc="old",} 0.0
opensearch_jvm_gc_collection_time_seconds{cluster="develop",node="develop01",gc="young",} 0.0
# HELP opensearch_indices_requestcache_memory_size_bytes Memory used for request cache
# TYPE opensearch_indices_requestcache_memory_size_bytes gauge
opensearch_indices_requestcache_memory_size_bytes{cluster="develop",node="develop01",} 0.0
# HELP opensearch_indices_search_open_contexts_number Number of search open contexts
# TYPE opensearch_indices_search_open_contexts_number gauge
opensearch_indices_search_open_contexts_number{cluster="develop",node="develop01",} 0.0
# HELP opensearch_jvm_mem_nonheap_used_bytes Memory used apart from heap
# TYPE opensearch_jvm_mem_nonheap_used_bytes gauge
opensearch_jvm_mem_nonheap_used_bytes{cluster="develop",node="develop01",} 5.5302736E7
...
On your Prometheus servers, configure a new job as usual.
For example, if you have a cluster of 3 nodes:
- job_name: opensearch
scrape_interval: 10s
metrics_path: "/_prometheus/metrics"
static_configs:
- targets:
- node1:9200
- node2:9200
- node3:9200
Of course, you could use the service discovery service instead of a static config.
Just keep in mind that metrics_path
must be /_prometheus/metrics
, otherwise Prometheus will find no metric.
To build the plugin you need JDK 17:
./gradlew clean build
If you have doubts about the system requirements, please check the CI.yml file for more information.
Project contains:
- integration tests implemented using rest layer framework
- internal cluster tests
Complete test suite is run using:
./gradlew clean check
To run individual integration rest test file use:
./gradlew :yamlRestTest \
-Dtests.method="test {yaml=/20_11_index_level_metrics_disabled/Dynamically disable index level metrics}"
Backward Compatibility (BWC) Testing is run manually using provided shell script:
./bwctest.sh
It is not part of ./gradlew [build|check]
task(s), but it is included in the CI workflow.
OpenSearch versions used during BWC tests use determined by properties located in gradle.properties
file. Specifically project.version
and project.BWCversion
. Version of plugin deployed into project.BWCversion
cluster is specified by project.BWCPluginVersion
property.
In the beginning of BWC tests the actual version of plugin (project.version
) is build using bundlePlugin
gradle task and the project.BWCPluginVersion
plugin is downloaded from GitHub releases. Both ZIP files are placed into src/test/resource/org/opensearch/prometheus-exrpoter/bwc/prometheus-exporter
folder (this folder is ignored by git).
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Prometheus is a registered trademark of The Linux Foundation. OpenSearch is a registered trademark of Amazon Web Services. Elasticsearch is a registered trademark of Elasticsearch BV.