Elasticsearch exporter Build Status

Crates.io Documentation BSD-3 licensed

Prometheus Elasticsearch exporter capable of working with large clusters. Caution you may overload Prometheus server by enabling all metrics, exporter is capable to export over near 1 million metrics. To avoid overloading Prometheus server run multiple Elasticsearch exporters that target just few specific metrics.

bash $ curl -s http://127.0.0.1:9222/metrics | wc 940272 1887011 153668390

Features

Options

shell $ curl -s http://127.0.0.1:9222 Vinted Elasticsearch exporter elasticsearch_url: http://127.0.0.1:9200 elasticsearch_global_timeout: 30s exporter_skip_labels: - cat_allocation: health,status - cat_fielddata: id - cat_indices: health,status - cat_nodeattrs: id - cat_nodes: health,status,pid - cat_plugins: id,description - cat_segments: health,status,checkpoint,prirep - cat_shards: health,status,checkpoint,prirep - cat_templates: composed_of - cat_thread_pool: node_id,ephemeral_node_id,pid - cat_transforms: health,status - cluster_stats: segment,patterns exporter_include_labels: - cat_aliases: index,alias - cat_allocation: node - cat_fielddata: node,field - cat_health: shards - cat_indices: index - cat_nodeattrs: node,attr - cat_nodes: index,name,node_role - cat_pending_tasks: index - cat_plugins: name - cat_recovery: index,shard,stage,type - cat_repositories: index - cat_segments: index,shard - cat_shards: index,node,shard - cat_templates: name,index_patterns - cat_thread_pool: node_name,name,type - cat_transforms: index - cluster_health: status - nodes_info: name - nodes_stats: name,vin_cluster_version - nodes_usage: name exporter_skip_metrics: - cat_aliases: filter,routing_index,routing_search,is_write_index - cat_nodeattrs: pid - cat_recovery: start_time,start_time_millis,stop_time,stop_time_millis - cat_templates: order - nodes_usage: _nodes_total,_nodes_successful,since exporter_poll_default_interval: 5s exporter_poll_intervals: - cluster_health: 5s exporter_histogram_buckets: [0.02, 0.04, 0.06, 0.08, 0.1, 0.25, 0.5, 0.75, 1.0, 2.0, 4.0, 6.0, 8.0, 10.0, 20.0, 30.0, 40.0, 50.0, 60.0] in seconds exporter_skip_zero_metrics: true exporter_metrics_enabled: - cat_health: true - cat_indices: true - nodes_info: true - nodes_stats: true exporter_metadata_refresh_interval: 300s

Self exporter metrics

```

HELP elasticsearchsubsystemrequestdurationseconds The Elasticsearch subsystem request latencies in seconds.

TYPE elasticsearchsubsystemrequestdurationseconds histogram

elasticsearchsubsystemrequestdurationsecondsbucket{cluster="devnull",subsystem="/nodes/os",le="0.005"} 0 elasticsearchsubsystemrequestdurationsecondssum{cluster="devnull",subsystem="/nodesstats"} 0.130069193 elasticsearchsubsystemrequestdurationsecondscount{cluster="devnull",subsystem="/nodesstats"} 1

HELP httprequestduration_seconds The HTTP request latencies in seconds.

TYPE httprequestduration_seconds histogram

httprequestdurationsecondsbucket{handler="/metrics",le="0.005"} 1 httprequestdurationsecondssum{handler="/metrics"} 0.004372555 httprequestdurationsecondscount{handler="/metrics"} 1

HELP processcpuseconds_total Total user and system CPU time spent in seconds.

TYPE processcpuseconds_total counter

processcpuseconds_total 0.24

HELP processmaxfds Maximum number of open file descriptors.

TYPE processmaxfds gauge

processmaxfds 1024

HELP processopenfds Number of open file descriptors.

TYPE processopenfds gauge

processopenfds 16

HELP processresidentmemory_bytes Resident memory size in bytes.

TYPE processresidentmemory_bytes gauge

processresidentmemory_bytes 25006080

HELP processstarttime_seconds Start time of the process since unix epoch in seconds.

TYPE processstarttime_seconds gauge

processstarttime_seconds 1605894185.46

HELP processvirtualmemory_bytes Virtual memory size in bytes.

TYPE processvirtualmemory_bytes gauge

processvirtualmemory_bytes 1345773568 ```

Development

To start:

shell cargo run --bin elasticsearch_exporter

To test:

shell cargo test

License

BSD-3-Clause