mirror of
https://github.com/prometheus/prometheus.git
synced 2024-11-10 07:34:04 -08:00
d9347bf128
Signed-off-by: Julien Pivotto <roidelapluie@o11y.eu>
3222 lines
122 KiB
Markdown
3222 lines
122 KiB
Markdown
---
|
||
title: Configuration
|
||
sort_rank: 1
|
||
---
|
||
|
||
# Configuration
|
||
|
||
Prometheus is configured via command-line flags and a configuration file. While
|
||
the command-line flags configure immutable system parameters (such as storage
|
||
locations, amount of data to keep on disk and in memory, etc.), the
|
||
configuration file defines everything related to scraping [jobs and their
|
||
instances](https://prometheus.io/docs/concepts/jobs_instances/), as well as
|
||
which [rule files to load](recording_rules.md#configuring-rules).
|
||
|
||
To view all available command-line flags, run `./prometheus -h`.
|
||
|
||
Prometheus can reload its configuration at runtime. If the new configuration
|
||
is not well-formed, the changes will not be applied.
|
||
A configuration reload is triggered by sending a `SIGHUP` to the Prometheus process or
|
||
sending a HTTP POST request to the `/-/reload` endpoint (when the `--web.enable-lifecycle` flag is enabled).
|
||
This will also reload any configured rule files.
|
||
|
||
## Configuration file
|
||
|
||
To specify which configuration file to load, use the `--config.file` flag.
|
||
|
||
The file is written in [YAML format](https://en.wikipedia.org/wiki/YAML),
|
||
defined by the scheme described below.
|
||
Brackets indicate that a parameter is optional. For non-list parameters the
|
||
value is set to the specified default.
|
||
|
||
Generic placeholders are defined as follows:
|
||
|
||
* `<boolean>`: a boolean that can take the values `true` or `false`
|
||
* `<duration>`: a duration matching the regular expression `((([0-9]+)y)?(([0-9]+)w)?(([0-9]+)d)?(([0-9]+)h)?(([0-9]+)m)?(([0-9]+)s)?(([0-9]+)ms)?|0)`, e.g. `1d`, `1h30m`, `5m`, `10s`
|
||
* `<filename>`: a valid path in the current working directory
|
||
* `<float>`: a floating-point number
|
||
* `<host>`: a valid string consisting of a hostname or IP followed by an optional port number
|
||
* `<int>`: an integer value
|
||
* `<labelname>`: a string matching the regular expression `[a-zA-Z_][a-zA-Z0-9_]*`
|
||
* `<labelvalue>`: a string of unicode characters
|
||
* `<path>`: a valid URL path
|
||
* `<scheme>`: a string that can take the values `http` or `https`
|
||
* `<secret>`: a regular string that is a secret, such as a password
|
||
* `<string>`: a regular string
|
||
* `<size>`: a size in bytes, e.g. `512MB`. A unit is required. Supported units: B, KB, MB, GB, TB, PB, EB.
|
||
* `<tmpl_string>`: a string which is template-expanded before usage
|
||
|
||
The other placeholders are specified separately.
|
||
|
||
A valid example file can be found [here](/config/testdata/conf.good.yml).
|
||
|
||
The global configuration specifies parameters that are valid in all other configuration
|
||
contexts. They also serve as defaults for other configuration sections.
|
||
|
||
```yaml
|
||
global:
|
||
# How frequently to scrape targets by default.
|
||
[ scrape_interval: <duration> | default = 1m ]
|
||
|
||
# How long until a scrape request times out.
|
||
[ scrape_timeout: <duration> | default = 10s ]
|
||
|
||
# How frequently to evaluate rules.
|
||
[ evaluation_interval: <duration> | default = 1m ]
|
||
|
||
# The labels to add to any time series or alerts when communicating with
|
||
# external systems (federation, remote storage, Alertmanager).
|
||
external_labels:
|
||
[ <labelname>: <labelvalue> ... ]
|
||
|
||
# File to which PromQL queries are logged.
|
||
# Reloading the configuration will reopen the file.
|
||
[ query_log_file: <string> ]
|
||
|
||
# Rule files specifies a list of globs. Rules and alerts are read from
|
||
# all matching files.
|
||
rule_files:
|
||
[ - <filepath_glob> ... ]
|
||
|
||
# A list of scrape configurations.
|
||
scrape_configs:
|
||
[ - <scrape_config> ... ]
|
||
|
||
# Alerting specifies settings related to the Alertmanager.
|
||
alerting:
|
||
alert_relabel_configs:
|
||
[ - <relabel_config> ... ]
|
||
alertmanagers:
|
||
[ - <alertmanager_config> ... ]
|
||
|
||
# Settings related to the remote write feature.
|
||
remote_write:
|
||
[ - <remote_write> ... ]
|
||
|
||
# Settings related to the remote read feature.
|
||
remote_read:
|
||
[ - <remote_read> ... ]
|
||
|
||
# Storage related settings that are runtime reloadable.
|
||
storage:
|
||
[ exemplars: <exemplars> ]
|
||
|
||
# Configures exporting traces.
|
||
tracing:
|
||
[ <tracing_config> ]
|
||
```
|
||
|
||
### `<scrape_config>`
|
||
|
||
A `scrape_config` section specifies a set of targets and parameters describing how
|
||
to scrape them. In the general case, one scrape configuration specifies a single
|
||
job. In advanced configurations, this may change.
|
||
|
||
Targets may be statically configured via the `static_configs` parameter or
|
||
dynamically discovered using one of the supported service-discovery mechanisms.
|
||
|
||
Additionally, `relabel_configs` allow advanced modifications to any
|
||
target and its labels before scraping.
|
||
|
||
```yaml
|
||
# The job name assigned to scraped metrics by default.
|
||
job_name: <job_name>
|
||
|
||
# How frequently to scrape targets from this job.
|
||
[ scrape_interval: <duration> | default = <global_config.scrape_interval> ]
|
||
|
||
# Per-scrape timeout when scraping this job.
|
||
[ scrape_timeout: <duration> | default = <global_config.scrape_timeout> ]
|
||
|
||
# The HTTP resource path on which to fetch metrics from targets.
|
||
[ metrics_path: <path> | default = /metrics ]
|
||
|
||
# honor_labels controls how Prometheus handles conflicts between labels that are
|
||
# already present in scraped data and labels that Prometheus would attach
|
||
# server-side ("job" and "instance" labels, manually configured target
|
||
# labels, and labels generated by service discovery implementations).
|
||
#
|
||
# If honor_labels is set to "true", label conflicts are resolved by keeping label
|
||
# values from the scraped data and ignoring the conflicting server-side labels.
|
||
#
|
||
# If honor_labels is set to "false", label conflicts are resolved by renaming
|
||
# conflicting labels in the scraped data to "exported_<original-label>" (for
|
||
# example "exported_instance", "exported_job") and then attaching server-side
|
||
# labels.
|
||
#
|
||
# Setting honor_labels to "true" is useful for use cases such as federation and
|
||
# scraping the Pushgateway, where all labels specified in the target should be
|
||
# preserved.
|
||
#
|
||
# Note that any globally configured "external_labels" are unaffected by this
|
||
# setting. In communication with external systems, they are always applied only
|
||
# when a time series does not have a given label yet and are ignored otherwise.
|
||
[ honor_labels: <boolean> | default = false ]
|
||
|
||
# honor_timestamps controls whether Prometheus respects the timestamps present
|
||
# in scraped data.
|
||
#
|
||
# If honor_timestamps is set to "true", the timestamps of the metrics exposed
|
||
# by the target will be used.
|
||
#
|
||
# If honor_timestamps is set to "false", the timestamps of the metrics exposed
|
||
# by the target will be ignored.
|
||
[ honor_timestamps: <boolean> | default = true ]
|
||
|
||
# Configures the protocol scheme used for requests.
|
||
[ scheme: <scheme> | default = http ]
|
||
|
||
# Optional HTTP URL parameters.
|
||
params:
|
||
[ <string>: [<string>, ...] ]
|
||
|
||
# Sets the `Authorization` header on every scrape request with the
|
||
# configured username and password.
|
||
# password and password_file are mutually exclusive.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Sets the `Authorization` header on every scrape request with
|
||
# the configured credentials.
|
||
authorization:
|
||
# Sets the authentication type of the request.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials of the request. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials of the request with the credentials read from the
|
||
# configured file. It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configure whether scrape requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# Configures the scrape request's TLS settings.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# List of Azure service discovery configurations.
|
||
azure_sd_configs:
|
||
[ - <azure_sd_config> ... ]
|
||
|
||
# List of Consul service discovery configurations.
|
||
consul_sd_configs:
|
||
[ - <consul_sd_config> ... ]
|
||
|
||
# List of DigitalOcean service discovery configurations.
|
||
digitalocean_sd_configs:
|
||
[ - <digitalocean_sd_config> ... ]
|
||
|
||
# List of Docker service discovery configurations.
|
||
docker_sd_configs:
|
||
[ - <docker_sd_config> ... ]
|
||
|
||
# List of Docker Swarm service discovery configurations.
|
||
dockerswarm_sd_configs:
|
||
[ - <dockerswarm_sd_config> ... ]
|
||
|
||
# List of DNS service discovery configurations.
|
||
dns_sd_configs:
|
||
[ - <dns_sd_config> ... ]
|
||
|
||
# List of EC2 service discovery configurations.
|
||
ec2_sd_configs:
|
||
[ - <ec2_sd_config> ... ]
|
||
|
||
# List of Eureka service discovery configurations.
|
||
eureka_sd_configs:
|
||
[ - <eureka_sd_config> ... ]
|
||
|
||
# List of file service discovery configurations.
|
||
file_sd_configs:
|
||
[ - <file_sd_config> ... ]
|
||
|
||
# List of GCE service discovery configurations.
|
||
gce_sd_configs:
|
||
[ - <gce_sd_config> ... ]
|
||
|
||
# List of Hetzner service discovery configurations.
|
||
hetzner_sd_configs:
|
||
[ - <hetzner_sd_config> ... ]
|
||
|
||
# List of HTTP service discovery configurations.
|
||
http_sd_configs:
|
||
[ - <http_sd_config> ... ]
|
||
|
||
|
||
# List of IONOS service discovery configurations.
|
||
ionos_sd_configs:
|
||
[ - <ionos_sd_config> ... ]
|
||
|
||
# List of Kubernetes service discovery configurations.
|
||
kubernetes_sd_configs:
|
||
[ - <kubernetes_sd_config> ... ]
|
||
|
||
# List of Kuma service discovery configurations.
|
||
kuma_sd_configs:
|
||
[ - <kuma_sd_config> ... ]
|
||
|
||
# List of Lightsail service discovery configurations.
|
||
lightsail_sd_configs:
|
||
[ - <lightsail_sd_config> ... ]
|
||
|
||
# List of Linode service discovery configurations.
|
||
linode_sd_configs:
|
||
[ - <linode_sd_config> ... ]
|
||
|
||
# List of Marathon service discovery configurations.
|
||
marathon_sd_configs:
|
||
[ - <marathon_sd_config> ... ]
|
||
|
||
# List of AirBnB's Nerve service discovery configurations.
|
||
nerve_sd_configs:
|
||
[ - <nerve_sd_config> ... ]
|
||
|
||
# List of Nomad service discovery configurations.
|
||
nomad_sd_configs:
|
||
[ - <nomad_sd_config> ... ]
|
||
|
||
# List of OpenStack service discovery configurations.
|
||
openstack_sd_configs:
|
||
[ - <openstack_sd_config> ... ]
|
||
|
||
# List of PuppetDB service discovery configurations.
|
||
puppetdb_sd_configs:
|
||
[ - <puppetdb_sd_config> ... ]
|
||
|
||
# List of Scaleway service discovery configurations.
|
||
scaleway_sd_configs:
|
||
[ - <scaleway_sd_config> ... ]
|
||
|
||
# List of Zookeeper Serverset service discovery configurations.
|
||
serverset_sd_configs:
|
||
[ - <serverset_sd_config> ... ]
|
||
|
||
# List of Triton service discovery configurations.
|
||
triton_sd_configs:
|
||
[ - <triton_sd_config> ... ]
|
||
|
||
# List of Uyuni service discovery configurations.
|
||
uyuni_sd_configs:
|
||
[ - <uyuni_sd_config> ... ]
|
||
|
||
# List of labeled statically configured targets for this job.
|
||
static_configs:
|
||
[ - <static_config> ... ]
|
||
|
||
# List of target relabel configurations.
|
||
relabel_configs:
|
||
[ - <relabel_config> ... ]
|
||
|
||
# List of metric relabel configurations.
|
||
metric_relabel_configs:
|
||
[ - <relabel_config> ... ]
|
||
|
||
# An uncompressed response body larger than this many bytes will cause the
|
||
# scrape to fail. 0 means no limit. Example: 100MB.
|
||
# This is an experimental feature, this behaviour could
|
||
# change or be removed in the future.
|
||
[ body_size_limit: <size> | default = 0 ]
|
||
# Per-scrape limit on number of scraped samples that will be accepted.
|
||
# If more than this number of samples are present after metric relabeling
|
||
# the entire scrape will be treated as failed. 0 means no limit.
|
||
[ sample_limit: <int> | default = 0 ]
|
||
|
||
# Per-scrape limit on number of labels that will be accepted for a sample. If
|
||
# more than this number of labels are present post metric-relabeling, the
|
||
# entire scrape will be treated as failed. 0 means no limit.
|
||
[ label_limit: <int> | default = 0 ]
|
||
|
||
# Per-scrape limit on length of labels name that will be accepted for a sample.
|
||
# If a label name is longer than this number post metric-relabeling, the entire
|
||
# scrape will be treated as failed. 0 means no limit.
|
||
[ label_name_length_limit: <int> | default = 0 ]
|
||
|
||
# Per-scrape limit on length of labels value that will be accepted for a sample.
|
||
# If a label value is longer than this number post metric-relabeling, the
|
||
# entire scrape will be treated as failed. 0 means no limit.
|
||
[ label_value_length_limit: <int> | default = 0 ]
|
||
|
||
# Per-scrape config limit on number of unique targets that will be
|
||
# accepted. If more than this number of targets are present after target
|
||
# relabeling, Prometheus will mark the targets as failed without scraping them.
|
||
# 0 means no limit. This is an experimental feature, this behaviour could
|
||
# change in the future.
|
||
[ target_limit: <int> | default = 0 ]
|
||
```
|
||
|
||
Where `<job_name>` must be unique across all scrape configurations.
|
||
|
||
### `<tls_config>`
|
||
|
||
A `tls_config` allows configuring TLS connections.
|
||
|
||
```yaml
|
||
# CA certificate to validate API server certificate with.
|
||
[ ca_file: <filename> ]
|
||
|
||
# Certificate and key files for client cert authentication to the server.
|
||
[ cert_file: <filename> ]
|
||
[ key_file: <filename> ]
|
||
|
||
# ServerName extension to indicate the name of the server.
|
||
# https://tools.ietf.org/html/rfc4366#section-3.1
|
||
[ server_name: <string> ]
|
||
|
||
# Disable validation of the server certificate.
|
||
[ insecure_skip_verify: <boolean> ]
|
||
|
||
# Minimum acceptable TLS version. Accepted values: TLS10 (TLS 1.0), TLS11 (TLS
|
||
# 1.1), TLS12 (TLS 1.2), TLS13 (TLS 1.3).
|
||
# If unset, Prometheus will use Go default minimum version, which is TLS 1.2.
|
||
# See MinVersion in https://pkg.go.dev/crypto/tls#Config.
|
||
[ min_version: <string> ]
|
||
```
|
||
|
||
### `<oauth2>`
|
||
|
||
OAuth 2.0 authentication using the client credentials grant type.
|
||
Prometheus fetches an access token from the specified endpoint with
|
||
the given client access and secret keys.
|
||
|
||
```yaml
|
||
client_id: <string>
|
||
[ client_secret: <secret> ]
|
||
|
||
# Read the client secret from a file.
|
||
# It is mutually exclusive with `client_secret`.
|
||
[ client_secret_file: <filename> ]
|
||
|
||
# Scopes for the token request.
|
||
scopes:
|
||
[ - <string> ... ]
|
||
|
||
# The URL to fetch the token from.
|
||
token_url: <string>
|
||
|
||
# Optional parameters to append to the token URL.
|
||
endpoint_params:
|
||
[ <string>: <string> ... ]
|
||
|
||
# Configures the token request's TLS settings.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
```
|
||
|
||
### `<azure_sd_config>`
|
||
|
||
Azure SD configurations allow retrieving scrape targets from Azure VMs.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_azure_machine_id`: the machine ID
|
||
* `__meta_azure_machine_location`: the location the machine runs in
|
||
* `__meta_azure_machine_name`: the machine name
|
||
* `__meta_azure_machine_computer_name`: the machine computer name
|
||
* `__meta_azure_machine_os_type`: the machine operating system
|
||
* `__meta_azure_machine_private_ip`: the machine's private IP
|
||
* `__meta_azure_machine_public_ip`: the machine's public IP if it exists
|
||
* `__meta_azure_machine_resource_group`: the machine's resource group
|
||
* `__meta_azure_machine_tag_<tagname>`: each tag value of the machine
|
||
* `__meta_azure_machine_scale_set`: the name of the scale set which the vm is part of (this value is only set if you are using a [scale set](https://docs.microsoft.com/en-us/azure/virtual-machine-scale-sets/))
|
||
* `__meta_azure_subscription_id`: the subscription ID
|
||
* `__meta_azure_tenant_id`: the tenant ID
|
||
|
||
See below for the configuration options for Azure discovery:
|
||
|
||
```yaml
|
||
# The information to access the Azure API.
|
||
# The Azure environment.
|
||
[ environment: <string> | default = AzurePublicCloud ]
|
||
|
||
# The authentication method, either OAuth or ManagedIdentity.
|
||
# See https://docs.microsoft.com/en-us/azure/active-directory/managed-identities-azure-resources/overview
|
||
[ authentication_method: <string> | default = OAuth]
|
||
# The subscription ID. Always required.
|
||
subscription_id: <string>
|
||
# Optional tenant ID. Only required with authentication_method OAuth.
|
||
[ tenant_id: <string> ]
|
||
# Optional client ID. Only required with authentication_method OAuth.
|
||
[ client_id: <string> ]
|
||
# Optional client secret. Only required with authentication_method OAuth.
|
||
[ client_secret: <secret> ]
|
||
|
||
# Optional resource group name. Limits discovery to this resource group.
|
||
[ resource_group: <string> ]
|
||
|
||
# Refresh interval to re-read the instance list.
|
||
[ refresh_interval: <duration> | default = 300s ]
|
||
|
||
# The port to scrape metrics from. If using the public IP address, this must
|
||
# instead be specified in the relabeling rule.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# Authentication information used to authenticate to the Azure API.
|
||
# Note that `basic_auth`, `authorization` and `oauth2` options are
|
||
# mutually exclusive.
|
||
# `password` and `password_file` are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information, currently not support by Azure.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration, currently not supported by Azure.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration, currently not supported by Azure.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<consul_sd_config>`
|
||
|
||
Consul SD configurations allow retrieving scrape targets from [Consul's](https://www.consul.io)
|
||
Catalog API.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_consul_address`: the address of the target
|
||
* `__meta_consul_dc`: the datacenter name for the target
|
||
* `__meta_consul_health`: the health status of the service
|
||
* `__meta_consul_metadata_<key>`: each node metadata key value of the target
|
||
* `__meta_consul_node`: the node name defined for the target
|
||
* `__meta_consul_service_address`: the service address of the target
|
||
* `__meta_consul_service_id`: the service ID of the target
|
||
* `__meta_consul_service_metadata_<key>`: each service metadata key value of the target
|
||
* `__meta_consul_service_port`: the service port of the target
|
||
* `__meta_consul_service`: the name of the service the target belongs to
|
||
* `__meta_consul_tagged_address_<key>`: each node tagged address key value of the target
|
||
* `__meta_consul_tags`: the list of tags of the target joined by the tag separator
|
||
|
||
```yaml
|
||
# The information to access the Consul API. It is to be defined
|
||
# as the Consul documentation requires.
|
||
[ server: <host> | default = "localhost:8500" ]
|
||
[ token: <secret> ]
|
||
[ datacenter: <string> ]
|
||
# Namespaces are only supported in Consul Enterprise.
|
||
[ namespace: <string> ]
|
||
[ scheme: <string> | default = "http" ]
|
||
# The username and password fields are deprecated in favor of the basic_auth configuration.
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
|
||
# A list of services for which targets are retrieved. If omitted, all services
|
||
# are scraped.
|
||
services:
|
||
[ - <string> ]
|
||
|
||
# See https://www.consul.io/api/catalog.html#list-nodes-for-service to know more
|
||
# about the possible filters that can be used.
|
||
|
||
# An optional list of tags used to filter nodes for a given service. Services must contain all tags in the list.
|
||
tags:
|
||
[ - <string> ]
|
||
|
||
# Node metadata key/value pairs to filter nodes for a given service.
|
||
[ node_meta:
|
||
[ <string>: <string> ... ] ]
|
||
|
||
# The string by which Consul tags are joined into the tag label.
|
||
[ tag_separator: <string> | default = , ]
|
||
|
||
# Allow stale Consul results (see https://www.consul.io/api/features/consistency.html). Will reduce load on Consul.
|
||
[ allow_stale: <boolean> | default = true ]
|
||
|
||
# The time after which the provided names are refreshed.
|
||
# On large setup it might be a good idea to increase this value because the catalog will change all the time.
|
||
[ refresh_interval: <duration> | default = 30s ]
|
||
|
||
# Authentication information used to authenticate to the consul server.
|
||
# Note that `basic_auth`, `authorization` and `oauth2` options are
|
||
# mutually exclusive.
|
||
# `password` and `password_file` are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
Note that the IP number and port used to scrape the targets is assembled as
|
||
`<__meta_consul_address>:<__meta_consul_service_port>`. However, in some
|
||
Consul setups, the relevant address is in `__meta_consul_service_address`.
|
||
In those cases, you can use the [relabel](#relabel_config)
|
||
feature to replace the special `__address__` label.
|
||
|
||
The [relabeling phase](#relabel_config) is the preferred and more powerful
|
||
way to filter services or nodes for a service based on arbitrary labels. For
|
||
users with thousands of services it can be more efficient to use the Consul API
|
||
directly which has basic support for filtering nodes (currently by node
|
||
metadata and a single tag).
|
||
|
||
### `<digitalocean_sd_config>`
|
||
|
||
DigitalOcean SD configurations allow retrieving scrape targets from [DigitalOcean's](https://www.digitalocean.com/)
|
||
Droplets API.
|
||
This service discovery uses the public IPv4 address by default, by that can be
|
||
changed with relabelling, as demonstrated in [the Prometheus digitalocean-sd
|
||
configuration file](/documentation/examples/prometheus-digitalocean.yml).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_digitalocean_droplet_id`: the id of the droplet
|
||
* `__meta_digitalocean_droplet_name`: the name of the droplet
|
||
* `__meta_digitalocean_image`: the slug of the droplet's image
|
||
* `__meta_digitalocean_image_name`: the display name of the droplet's image
|
||
* `__meta_digitalocean_private_ipv4`: the private IPv4 of the droplet
|
||
* `__meta_digitalocean_public_ipv4`: the public IPv4 of the droplet
|
||
* `__meta_digitalocean_public_ipv6`: the public IPv6 of the droplet
|
||
* `__meta_digitalocean_region`: the region of the droplet
|
||
* `__meta_digitalocean_size`: the size of the droplet
|
||
* `__meta_digitalocean_status`: the status of the droplet
|
||
* `__meta_digitalocean_features`: the comma-separated list of features of the droplet
|
||
* `__meta_digitalocean_tags`: the comma-separated list of tags of the droplet
|
||
* `__meta_digitalocean_vpc`: the id of the droplet's VPC
|
||
|
||
```yaml
|
||
# Authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information, not currently supported by DigitalOcean.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The time after which the droplets are refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
```
|
||
|
||
### `<docker_sd_config>`
|
||
|
||
Docker SD configurations allow retrieving scrape targets from [Docker Engine](https://docs.docker.com/engine/) hosts.
|
||
|
||
This SD discovers "containers" and will create a target for each network IP and port the container is configured to expose.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_docker_container_id`: the id of the container
|
||
* `__meta_docker_container_name`: the name of the container
|
||
* `__meta_docker_container_network_mode`: the network mode of the container
|
||
* `__meta_docker_container_label_<labelname>`: each label of the container
|
||
* `__meta_docker_network_id`: the ID of the network
|
||
* `__meta_docker_network_name`: the name of the network
|
||
* `__meta_docker_network_ingress`: whether the network is ingress
|
||
* `__meta_docker_network_internal`: whether the network is internal
|
||
* `__meta_docker_network_label_<labelname>`: each label of the network
|
||
* `__meta_docker_network_scope`: the scope of the network
|
||
* `__meta_docker_network_ip`: the IP of the container in this network
|
||
* `__meta_docker_port_private`: the port on the container
|
||
* `__meta_docker_port_public`: the external port if a port-mapping exists
|
||
* `__meta_docker_port_public_ip`: the public IP if a port-mapping exists
|
||
|
||
See below for the configuration options for Docker discovery:
|
||
|
||
```yaml
|
||
# Address of the Docker daemon.
|
||
host: <string>
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# The port to scrape metrics from, when `role` is nodes, and for discovered
|
||
# tasks and services that don't have published ports.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The host to use if the container is in host networking mode.
|
||
[ host_networking_host: <string> | default = "localhost" ]
|
||
|
||
# Optional filters to limit the discovery process to a subset of available
|
||
# resources.
|
||
# The available filters are listed in the upstream documentation:
|
||
# https://docs.docker.com/engine/api/v1.40/#operation/ContainerList
|
||
[ filters:
|
||
[ - name: <string>
|
||
values: <string>, [...] ]
|
||
|
||
# The time after which the containers are refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# Authentication information used to authenticate to the Docker daemon.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
```
|
||
|
||
The [relabeling phase](#relabel_config) is the preferred and more powerful
|
||
way to filter containers. For users with thousands of containers it
|
||
can be more efficient to use the Docker API directly which has basic support for
|
||
filtering containers (using `filters`).
|
||
|
||
See [this example Prometheus configuration file](/documentation/examples/prometheus-docker.yml)
|
||
for a detailed example of configuring Prometheus for Docker Engine.
|
||
|
||
### `<dockerswarm_sd_config>`
|
||
|
||
Docker Swarm SD configurations allow retrieving scrape targets from [Docker Swarm](https://docs.docker.com/engine/swarm/)
|
||
engine.
|
||
|
||
One of the following roles can be configured to discover targets:
|
||
|
||
#### `services`
|
||
|
||
The `services` role discovers all [Swarm services](https://docs.docker.com/engine/swarm/key-concepts/#services-and-tasks)
|
||
and exposes their ports as targets. For each published port of a service, a
|
||
single target is generated. If a service has no published ports, a target per
|
||
service is created using the `port` parameter defined in the SD configuration.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_dockerswarm_service_id`: the id of the service
|
||
* `__meta_dockerswarm_service_name`: the name of the service
|
||
* `__meta_dockerswarm_service_mode`: the mode of the service
|
||
* `__meta_dockerswarm_service_endpoint_port_name`: the name of the endpoint port, if available
|
||
* `__meta_dockerswarm_service_endpoint_port_publish_mode`: the publish mode of the endpoint port
|
||
* `__meta_dockerswarm_service_label_<labelname>`: each label of the service
|
||
* `__meta_dockerswarm_service_task_container_hostname`: the container hostname of the target, if available
|
||
* `__meta_dockerswarm_service_task_container_image`: the container image of the target
|
||
* `__meta_dockerswarm_service_updating_status`: the status of the service, if available
|
||
* `__meta_dockerswarm_network_id`: the ID of the network
|
||
* `__meta_dockerswarm_network_name`: the name of the network
|
||
* `__meta_dockerswarm_network_ingress`: whether the network is ingress
|
||
* `__meta_dockerswarm_network_internal`: whether the network is internal
|
||
* `__meta_dockerswarm_network_label_<labelname>`: each label of the network
|
||
* `__meta_dockerswarm_network_scope`: the scope of the network
|
||
|
||
#### `tasks`
|
||
|
||
The `tasks` role discovers all [Swarm tasks](https://docs.docker.com/engine/swarm/key-concepts/#services-and-tasks)
|
||
and exposes their ports as targets. For each published port of a task, a single
|
||
target is generated. If a task has no published ports, a target per task is
|
||
created using the `port` parameter defined in the SD configuration.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_dockerswarm_container_label_<labelname>`: each label of the container
|
||
* `__meta_dockerswarm_task_id`: the id of the task
|
||
* `__meta_dockerswarm_task_container_id`: the container id of the task
|
||
* `__meta_dockerswarm_task_desired_state`: the desired state of the task
|
||
* `__meta_dockerswarm_task_slot`: the slot of the task
|
||
* `__meta_dockerswarm_task_state`: the state of the task
|
||
* `__meta_dockerswarm_task_port_publish_mode`: the publish mode of the task port
|
||
* `__meta_dockerswarm_service_id`: the id of the service
|
||
* `__meta_dockerswarm_service_name`: the name of the service
|
||
* `__meta_dockerswarm_service_mode`: the mode of the service
|
||
* `__meta_dockerswarm_service_label_<labelname>`: each label of the service
|
||
* `__meta_dockerswarm_network_id`: the ID of the network
|
||
* `__meta_dockerswarm_network_name`: the name of the network
|
||
* `__meta_dockerswarm_network_ingress`: whether the network is ingress
|
||
* `__meta_dockerswarm_network_internal`: whether the network is internal
|
||
* `__meta_dockerswarm_network_label_<labelname>`: each label of the network
|
||
* `__meta_dockerswarm_network_label`: each label of the network
|
||
* `__meta_dockerswarm_network_scope`: the scope of the network
|
||
* `__meta_dockerswarm_node_id`: the ID of the node
|
||
* `__meta_dockerswarm_node_hostname`: the hostname of the node
|
||
* `__meta_dockerswarm_node_address`: the address of the node
|
||
* `__meta_dockerswarm_node_availability`: the availability of the node
|
||
* `__meta_dockerswarm_node_label_<labelname>`: each label of the node
|
||
* `__meta_dockerswarm_node_platform_architecture`: the architecture of the node
|
||
* `__meta_dockerswarm_node_platform_os`: the operating system of the node
|
||
* `__meta_dockerswarm_node_role`: the role of the node
|
||
* `__meta_dockerswarm_node_status`: the status of the node
|
||
|
||
The `__meta_dockerswarm_network_*` meta labels are not populated for ports which
|
||
are published with `mode=host`.
|
||
|
||
#### `nodes`
|
||
|
||
The `nodes` role is used to discover [Swarm nodes](https://docs.docker.com/engine/swarm/key-concepts/#nodes).
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_dockerswarm_node_address`: the address of the node
|
||
* `__meta_dockerswarm_node_availability`: the availability of the node
|
||
* `__meta_dockerswarm_node_engine_version`: the version of the node engine
|
||
* `__meta_dockerswarm_node_hostname`: the hostname of the node
|
||
* `__meta_dockerswarm_node_id`: the ID of the node
|
||
* `__meta_dockerswarm_node_label_<labelname>`: each label of the node
|
||
* `__meta_dockerswarm_node_manager_address`: the address of the manager component of the node
|
||
* `__meta_dockerswarm_node_manager_leader`: the leadership status of the manager component of the node (true or false)
|
||
* `__meta_dockerswarm_node_manager_reachability`: the reachability of the manager component of the node
|
||
* `__meta_dockerswarm_node_platform_architecture`: the architecture of the node
|
||
* `__meta_dockerswarm_node_platform_os`: the operating system of the node
|
||
* `__meta_dockerswarm_node_role`: the role of the node
|
||
* `__meta_dockerswarm_node_status`: the status of the node
|
||
|
||
See below for the configuration options for Docker Swarm discovery:
|
||
|
||
```yaml
|
||
# Address of the Docker daemon.
|
||
host: <string>
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Role of the targets to retrieve. Must be `services`, `tasks`, or `nodes`.
|
||
role: <string>
|
||
|
||
# The port to scrape metrics from, when `role` is nodes, and for discovered
|
||
# tasks and services that don't have published ports.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# Optional filters to limit the discovery process to a subset of available
|
||
# resources.
|
||
# The available filters are listed in the upstream documentation:
|
||
# Services: https://docs.docker.com/engine/api/v1.40/#operation/ServiceList
|
||
# Tasks: https://docs.docker.com/engine/api/v1.40/#operation/TaskList
|
||
# Nodes: https://docs.docker.com/engine/api/v1.40/#operation/NodeList
|
||
[ filters:
|
||
[ - name: <string>
|
||
values: <string>, [...] ]
|
||
|
||
# The time after which the service discovery data is refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# Authentication information used to authenticate to the Docker daemon.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
```
|
||
|
||
The [relabeling phase](#relabel_config) is the preferred and more powerful
|
||
way to filter tasks, services or nodes. For users with thousands of tasks it
|
||
can be more efficient to use the Swarm API directly which has basic support for
|
||
filtering nodes (using `filters`).
|
||
|
||
See [this example Prometheus configuration file](/documentation/examples/prometheus-dockerswarm.yml)
|
||
for a detailed example of configuring Prometheus for Docker Swarm.
|
||
|
||
### `<dns_sd_config>`
|
||
|
||
A DNS-based service discovery configuration allows specifying a set of DNS
|
||
domain names which are periodically queried to discover a list of targets. The
|
||
DNS servers to be contacted are read from `/etc/resolv.conf`.
|
||
|
||
This service discovery method only supports basic DNS A, AAAA and SRV record
|
||
queries, but not the advanced DNS-SD approach specified in
|
||
[RFC6763](https://tools.ietf.org/html/rfc6763).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_dns_name`: the record name that produced the discovered target.
|
||
* `__meta_dns_srv_record_target`: the target field of the SRV record
|
||
* `__meta_dns_srv_record_port`: the port field of the SRV record
|
||
|
||
```yaml
|
||
# A list of DNS domain names to be queried.
|
||
names:
|
||
[ - <string> ]
|
||
|
||
# The type of DNS query to perform. One of SRV, A, or AAAA.
|
||
[ type: <string> | default = 'SRV' ]
|
||
|
||
# The port number used if the query type is not SRV.
|
||
[ port: <int>]
|
||
|
||
# The time after which the provided names are refreshed.
|
||
[ refresh_interval: <duration> | default = 30s ]
|
||
```
|
||
|
||
### `<ec2_sd_config>`
|
||
|
||
EC2 SD configurations allow retrieving scrape targets from AWS EC2
|
||
instances. The private IP address is used by default, but may be changed to
|
||
the public IP address with relabeling.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_ec2_ami`: the EC2 Amazon Machine Image
|
||
* `__meta_ec2_architecture`: the architecture of the instance
|
||
* `__meta_ec2_availability_zone`: the availability zone in which the instance is running
|
||
* `__meta_ec2_availability_zone_id`: the [availability zone ID](https://docs.aws.amazon.com/ram/latest/userguide/working-with-az-ids.html) in which the instance is running (requires `ec2:DescribeAvailabilityZones`)
|
||
* `__meta_ec2_instance_id`: the EC2 instance ID
|
||
* `__meta_ec2_instance_lifecycle`: the lifecycle of the EC2 instance, set only for 'spot' or 'scheduled' instances, absent otherwise
|
||
* `__meta_ec2_instance_state`: the state of the EC2 instance
|
||
* `__meta_ec2_instance_type`: the type of the EC2 instance
|
||
* `__meta_ec2_ipv6_addresses`: comma separated list of IPv6 addresses assigned to the instance's network interfaces, if present
|
||
* `__meta_ec2_owner_id`: the ID of the AWS account that owns the EC2 instance
|
||
* `__meta_ec2_platform`: the Operating System platform, set to 'windows' on Windows servers, absent otherwise
|
||
* `__meta_ec2_primary_subnet_id`: the subnet ID of the primary network interface, if available
|
||
* `__meta_ec2_private_dns_name`: the private DNS name of the instance, if available
|
||
* `__meta_ec2_private_ip`: the private IP address of the instance, if present
|
||
* `__meta_ec2_public_dns_name`: the public DNS name of the instance, if available
|
||
* `__meta_ec2_public_ip`: the public IP address of the instance, if available
|
||
* `__meta_ec2_subnet_id`: comma separated list of subnets IDs in which the instance is running, if available
|
||
* `__meta_ec2_tag_<tagkey>`: each tag value of the instance
|
||
* `__meta_ec2_vpc_id`: the ID of the VPC in which the instance is running, if available
|
||
|
||
See below for the configuration options for EC2 discovery:
|
||
|
||
```yaml
|
||
# The information to access the EC2 API.
|
||
|
||
# The AWS region. If blank, the region from the instance metadata is used.
|
||
[ region: <string> ]
|
||
|
||
# Custom endpoint to be used.
|
||
[ endpoint: <string> ]
|
||
|
||
# The AWS API keys. If blank, the environment variables `AWS_ACCESS_KEY_ID`
|
||
# and `AWS_SECRET_ACCESS_KEY` are used.
|
||
[ access_key: <string> ]
|
||
[ secret_key: <secret> ]
|
||
# Named AWS profile used to connect to the API.
|
||
[ profile: <string> ]
|
||
|
||
# AWS Role ARN, an alternative to using AWS API keys.
|
||
[ role_arn: <string> ]
|
||
|
||
# Refresh interval to re-read the instance list.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# The port to scrape metrics from. If using the public IP address, this must
|
||
# instead be specified in the relabeling rule.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# Filters can be used optionally to filter the instance list by other criteria.
|
||
# Available filter criteria can be found here:
|
||
# https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_DescribeInstances.html
|
||
# Filter API documentation: https://docs.aws.amazon.com/AWSEC2/latest/APIReference/API_Filter.html
|
||
filters:
|
||
[ - name: <string>
|
||
values: <string>, [...] ]
|
||
```
|
||
|
||
The [relabeling phase](#relabel_config) is the preferred and more powerful
|
||
way to filter targets based on arbitrary labels. For users with thousands of
|
||
instances it can be more efficient to use the EC2 API directly which has
|
||
support for filtering instances.
|
||
|
||
### `<openstack_sd_config>`
|
||
|
||
OpenStack SD configurations allow retrieving scrape targets from OpenStack Nova
|
||
instances.
|
||
|
||
One of the following `<openstack_role>` types can be configured to discover targets:
|
||
|
||
#### `hypervisor`
|
||
|
||
The `hypervisor` role discovers one target per Nova hypervisor node. The target
|
||
address defaults to the `host_ip` attribute of the hypervisor.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_openstack_hypervisor_host_ip`: the hypervisor node's IP address.
|
||
* `__meta_openstack_hypervisor_hostname`: the hypervisor node's name.
|
||
* `__meta_openstack_hypervisor_id`: the hypervisor node's ID.
|
||
* `__meta_openstack_hypervisor_state`: the hypervisor node's state.
|
||
* `__meta_openstack_hypervisor_status`: the hypervisor node's status.
|
||
* `__meta_openstack_hypervisor_type`: the hypervisor node's type.
|
||
|
||
#### `instance`
|
||
|
||
The `instance` role discovers one target per network interface of Nova
|
||
instance. The target address defaults to the private IP address of the network
|
||
interface.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_openstack_address_pool`: the pool of the private IP.
|
||
* `__meta_openstack_instance_flavor`: the flavor of the OpenStack instance.
|
||
* `__meta_openstack_instance_id`: the OpenStack instance ID.
|
||
* `__meta_openstack_instance_name`: the OpenStack instance name.
|
||
* `__meta_openstack_instance_status`: the status of the OpenStack instance.
|
||
* `__meta_openstack_private_ip`: the private IP of the OpenStack instance.
|
||
* `__meta_openstack_project_id`: the project (tenant) owning this instance.
|
||
* `__meta_openstack_public_ip`: the public IP of the OpenStack instance.
|
||
* `__meta_openstack_tag_<tagkey>`: each tag value of the instance.
|
||
* `__meta_openstack_user_id`: the user account owning the tenant.
|
||
|
||
See below for the configuration options for OpenStack discovery:
|
||
|
||
```yaml
|
||
# The information to access the OpenStack API.
|
||
|
||
# The OpenStack role of entities that should be discovered.
|
||
role: <openstack_role>
|
||
|
||
# The OpenStack Region.
|
||
region: <string>
|
||
|
||
# identity_endpoint specifies the HTTP endpoint that is required to work with
|
||
# the Identity API of the appropriate version. While it's ultimately needed by
|
||
# all of the identity services, it will often be populated by a provider-level
|
||
# function.
|
||
[ identity_endpoint: <string> ]
|
||
|
||
# username is required if using Identity V2 API. Consult with your provider's
|
||
# control panel to discover your account's username. In Identity V3, either
|
||
# userid or a combination of username and domain_id or domain_name are needed.
|
||
[ username: <string> ]
|
||
[ userid: <string> ]
|
||
|
||
# password for the Identity V2 and V3 APIs. Consult with your provider's
|
||
# control panel to discover your account's preferred method of authentication.
|
||
[ password: <secret> ]
|
||
|
||
# At most one of domain_id and domain_name must be provided if using username
|
||
# with Identity V3. Otherwise, either are optional.
|
||
[ domain_name: <string> ]
|
||
[ domain_id: <string> ]
|
||
|
||
# The project_id and project_name fields are optional for the Identity V2 API.
|
||
# Some providers allow you to specify a project_name instead of the project_id.
|
||
# Some require both. Your provider's authentication policies will determine
|
||
# how these fields influence authentication.
|
||
[ project_name: <string> ]
|
||
[ project_id: <string> ]
|
||
|
||
# The application_credential_id or application_credential_name fields are
|
||
# required if using an application credential to authenticate. Some providers
|
||
# allow you to create an application credential to authenticate rather than a
|
||
# password.
|
||
[ application_credential_name: <string> ]
|
||
[ application_credential_id: <string> ]
|
||
|
||
# The application_credential_secret field is required if using an application
|
||
# credential to authenticate.
|
||
[ application_credential_secret: <secret> ]
|
||
|
||
# Whether the service discovery should list all instances for all projects.
|
||
# It is only relevant for the 'instance' role and usually requires admin permissions.
|
||
[ all_tenants: <boolean> | default: false ]
|
||
|
||
# Refresh interval to re-read the instance list.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# The port to scrape metrics from. If using the public IP address, this must
|
||
# instead be specified in the relabeling rule.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The availability of the endpoint to connect to. Must be one of public, admin or internal.
|
||
[ availability: <string> | default = "public" ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<puppetdb_sd_config>`
|
||
|
||
PuppetDB SD configurations allow retrieving scrape targets from
|
||
[PuppetDB](https://puppet.com/docs/puppetdb/latest/index.html) resources.
|
||
|
||
This SD discovers resources and will create a target for each resource returned
|
||
by the API.
|
||
|
||
The resource address is the `certname` of the resource and can be changed during
|
||
[relabeling](#relabel_config).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_puppetdb_certname`: the name of the node associated with the resource
|
||
* `__meta_puppetdb_resource`: a SHA-1 hash of the resource’s type, title, and parameters, for identification
|
||
* `__meta_puppetdb_type`: the resource type
|
||
* `__meta_puppetdb_title`: the resource title
|
||
* `__meta_puppetdb_exported`: whether the resource is exported (`"true"` or `"false"`)
|
||
* `__meta_puppetdb_tags`: comma separated list of resource tags
|
||
* `__meta_puppetdb_file`: the manifest file in which the resource was declared
|
||
* `__meta_puppetdb_environment`: the environment of the node associated with the resource
|
||
* `__meta_puppetdb_parameter_<parametername>`: the parameters of the resource
|
||
|
||
|
||
See below for the configuration options for PuppetDB discovery:
|
||
|
||
```yaml
|
||
# The URL of the PuppetDB root query endpoint.
|
||
url: <string>
|
||
|
||
# Puppet Query Language (PQL) query. Only resources are supported.
|
||
# https://puppet.com/docs/puppetdb/latest/api/query/v4/pql.html
|
||
query: <string>
|
||
|
||
# Whether to include the parameters as meta labels.
|
||
# Due to the differences between parameter types and Prometheus labels,
|
||
# some parameters might not be rendered. The format of the parameters might
|
||
# also change in future releases.
|
||
#
|
||
# Note: Enabling this exposes parameters in the Prometheus UI and API. Make sure
|
||
# that you don't have secrets exposed as parameters if you enable this.
|
||
[ include_parameters: <boolean> | default = false ]
|
||
|
||
# Refresh interval to re-read the resources list.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# TLS configuration to connect to the PuppetDB.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# basic_auth, authorization, and oauth2, are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# `Authorization` HTTP header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials with the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
```
|
||
|
||
See [this example Prometheus configuration file](/documentation/examples/prometheus-puppetdb.yml)
|
||
for a detailed example of configuring Prometheus with PuppetDB.
|
||
|
||
|
||
### `<file_sd_config>`
|
||
|
||
File-based service discovery provides a more generic way to configure static targets
|
||
and serves as an interface to plug in custom service discovery mechanisms.
|
||
|
||
It reads a set of files containing a list of zero or more
|
||
`<static_config>`s. Changes to all defined files are detected via disk watches
|
||
and applied immediately. Files may be provided in YAML or JSON format. Only
|
||
changes resulting in well-formed target groups are applied.
|
||
|
||
Files must contain a list of static configs, using these formats:
|
||
|
||
**JSON**
|
||
```json
|
||
[
|
||
{
|
||
"targets": [ "<host>", ... ],
|
||
"labels": {
|
||
"<labelname>": "<labelvalue>", ...
|
||
}
|
||
},
|
||
...
|
||
]
|
||
```
|
||
|
||
**YAML**
|
||
```yaml
|
||
- targets:
|
||
[ - '<host>' ]
|
||
labels:
|
||
[ <labelname>: <labelvalue> ... ]
|
||
```
|
||
|
||
As a fallback, the file contents are also re-read periodically at the specified
|
||
refresh interval.
|
||
|
||
Each target has a meta label `__meta_filepath` during the
|
||
[relabeling phase](#relabel_config). Its value is set to the
|
||
filepath from which the target was extracted.
|
||
|
||
There is a list of
|
||
[integrations](https://prometheus.io/docs/operating/integrations/#file-service-discovery) with this
|
||
discovery mechanism.
|
||
|
||
```yaml
|
||
# Patterns for files from which target groups are extracted.
|
||
files:
|
||
[ - <filename_pattern> ... ]
|
||
|
||
# Refresh interval to re-read the files.
|
||
[ refresh_interval: <duration> | default = 5m ]
|
||
```
|
||
|
||
Where `<filename_pattern>` may be a path ending in `.json`, `.yml` or `.yaml`. The last path segment
|
||
may contain a single `*` that matches any character sequence, e.g. `my/path/tg_*.json`.
|
||
|
||
### `<gce_sd_config>`
|
||
|
||
[GCE](https://cloud.google.com/compute/) SD configurations allow retrieving scrape targets from GCP GCE instances.
|
||
The private IP address is used by default, but may be changed to the public IP
|
||
address with relabeling.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_gce_instance_id`: the numeric id of the instance
|
||
* `__meta_gce_instance_name`: the name of the instance
|
||
* `__meta_gce_label_<labelname>`: each GCE label of the instance
|
||
* `__meta_gce_machine_type`: full or partial URL of the machine type of the instance
|
||
* `__meta_gce_metadata_<name>`: each metadata item of the instance
|
||
* `__meta_gce_network`: the network URL of the instance
|
||
* `__meta_gce_private_ip`: the private IP address of the instance
|
||
* `__meta_gce_interface_ipv4_<name>`: IPv4 address of each named interface
|
||
* `__meta_gce_project`: the GCP project in which the instance is running
|
||
* `__meta_gce_public_ip`: the public IP address of the instance, if present
|
||
* `__meta_gce_subnetwork`: the subnetwork URL of the instance
|
||
* `__meta_gce_tags`: comma separated list of instance tags
|
||
* `__meta_gce_zone`: the GCE zone URL in which the instance is running
|
||
|
||
See below for the configuration options for GCE discovery:
|
||
|
||
```yaml
|
||
# The information to access the GCE API.
|
||
|
||
# The GCP Project
|
||
project: <string>
|
||
|
||
# The zone of the scrape targets. If you need multiple zones use multiple
|
||
# gce_sd_configs.
|
||
zone: <string>
|
||
|
||
# Filter can be used optionally to filter the instance list by other criteria
|
||
# Syntax of this filter string is described here in the filter query parameter section:
|
||
# https://cloud.google.com/compute/docs/reference/latest/instances/list
|
||
[ filter: <string> ]
|
||
|
||
# Refresh interval to re-read the instance list
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# The port to scrape metrics from. If using the public IP address, this must
|
||
# instead be specified in the relabeling rule.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The tag separator is used to separate the tags on concatenation
|
||
[ tag_separator: <string> | default = , ]
|
||
```
|
||
|
||
Credentials are discovered by the Google Cloud SDK default client by looking
|
||
in the following places, preferring the first location found:
|
||
|
||
1. a JSON file specified by the `GOOGLE_APPLICATION_CREDENTIALS` environment variable
|
||
2. a JSON file in the well-known path `$HOME/.config/gcloud/application_default_credentials.json`
|
||
3. fetched from the GCE metadata server
|
||
|
||
If Prometheus is running within GCE, the service account associated with the
|
||
instance it is running on should have at least read-only permissions to the
|
||
compute resources. If running outside of GCE make sure to create an appropriate
|
||
service account and place the credential file in one of the expected locations.
|
||
|
||
### `<hetzner_sd_config>`
|
||
|
||
Hetzner SD configurations allow retrieving scrape targets from
|
||
[Hetzner](https://www.hetzner.com/) [Cloud](https://www.hetzner.cloud/) API and
|
||
[Robot](https://docs.hetzner.com/robot/) API.
|
||
This service discovery uses the public IPv4 address by default, but that can be
|
||
changed with relabeling, as demonstrated in [the Prometheus hetzner-sd
|
||
configuration file](/documentation/examples/prometheus-hetzner.yml).
|
||
|
||
The following meta labels are available on all targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_hetzner_server_id`: the ID of the server
|
||
* `__meta_hetzner_server_name`: the name of the server
|
||
* `__meta_hetzner_server_status`: the status of the server
|
||
* `__meta_hetzner_public_ipv4`: the public ipv4 address of the server
|
||
* `__meta_hetzner_public_ipv6_network`: the public ipv6 network (/64) of the server
|
||
* `__meta_hetzner_datacenter`: the datacenter of the server
|
||
|
||
The labels below are only available for targets with `role` set to `hcloud`:
|
||
|
||
* `__meta_hetzner_hcloud_image_name`: the image name of the server
|
||
* `__meta_hetzner_hcloud_image_description`: the description of the server image
|
||
* `__meta_hetzner_hcloud_image_os_flavor`: the OS flavor of the server image
|
||
* `__meta_hetzner_hcloud_image_os_version`: the OS version of the server image
|
||
* `__meta_hetzner_hcloud_image_description`: the description of the server image
|
||
* `__meta_hetzner_hcloud_datacenter_location`: the location of the server
|
||
* `__meta_hetzner_hcloud_datacenter_location_network_zone`: the network zone of the server
|
||
* `__meta_hetzner_hcloud_server_type`: the type of the server
|
||
* `__meta_hetzner_hcloud_cpu_cores`: the CPU cores count of the server
|
||
* `__meta_hetzner_hcloud_cpu_type`: the CPU type of the server (shared or dedicated)
|
||
* `__meta_hetzner_hcloud_memory_size_gb`: the amount of memory of the server (in GB)
|
||
* `__meta_hetzner_hcloud_disk_size_gb`: the disk size of the server (in GB)
|
||
* `__meta_hetzner_hcloud_private_ipv4_<networkname>`: the private ipv4 address of the server within a given network
|
||
* `__meta_hetzner_hcloud_label_<labelname>`: each label of the server
|
||
* `__meta_hetzner_hcloud_labelpresent_<labelname>`: `true` for each label of the server
|
||
|
||
The labels below are only available for targets with `role` set to `robot`:
|
||
|
||
* `__meta_hetzner_robot_product`: the product of the server
|
||
* `__meta_hetzner_robot_cancelled`: the server cancellation status
|
||
|
||
```yaml
|
||
# The Hetzner role of entities that should be discovered.
|
||
# One of robot or hcloud.
|
||
role: <string>
|
||
|
||
# Authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information, required when role is robot
|
||
# Role hcloud does not support basic auth.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration, required when role is
|
||
# hcloud. Role robot does not support bearer token authentication.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The time after which the servers are refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
```
|
||
|
||
### `<http_sd_config>`
|
||
|
||
HTTP-based service discovery provides a more generic way to configure static targets
|
||
and serves as an interface to plug in custom service discovery mechanisms.
|
||
|
||
It fetches targets from an HTTP endpoint containing a list of zero or more
|
||
`<static_config>`s. The target must reply with an HTTP 200 response.
|
||
The HTTP header `Content-Type` must be `application/json`, and the body must be
|
||
valid JSON.
|
||
|
||
Example response body:
|
||
|
||
```json
|
||
[
|
||
{
|
||
"targets": [ "<host>", ... ],
|
||
"labels": {
|
||
"<labelname>": "<labelvalue>", ...
|
||
}
|
||
},
|
||
...
|
||
]
|
||
```
|
||
|
||
The endpoint is queried periodically at the specified refresh interval.
|
||
The `prometheus_sd_http_failures_total` counter metric tracks the number of
|
||
refresh failures.
|
||
|
||
Each target has a meta label `__meta_url` during the
|
||
[relabeling phase](#relabel_config). Its value is set to the
|
||
URL from which the target was extracted.
|
||
|
||
```yaml
|
||
# URL from which the targets are fetched.
|
||
url: <string>
|
||
|
||
# Refresh interval to re-query the endpoint.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# Authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth`, `authorization` and `oauth2` options are
|
||
# mutually exclusive.
|
||
# `password` and `password_file` are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<ionos_sd_config>`
|
||
|
||
IONOS SD configurations allows retrieving scrape targets from
|
||
[IONOS Cloud](https://cloud.ionos.com/) API. This service discovery uses the
|
||
first NICs IP address by default, but that can be changed with relabeling. The
|
||
following meta labels are available on all targets during
|
||
[relabeling](#relabel_config):
|
||
|
||
* `__meta_ionos_server_availability_zone`: the availability zone of the server
|
||
* `__meta_ionos_server_boot_cdrom_id`: the ID of the CD-ROM the server is booted
|
||
from
|
||
* `__meta_ionos_server_boot_image_id`: the ID of the boot image or snapshot the
|
||
server is booted from
|
||
* `__meta_ionos_server_boot_volume_id`: the ID of the boot volume
|
||
* `__meta_ionos_server_cpu_family`: the CPU family of the server
|
||
to
|
||
* `__meta_ionos_server_id`: the ID of the server
|
||
* `__meta_ionos_server_ip`: comma separated list of all IPs assigned to the
|
||
server
|
||
* `__meta_ionos_server_lifecycle`: the lifecycle state of the server resource
|
||
* `__meta_ionos_server_name`: the name of the server
|
||
* `__meta_ionos_server_nic_ip_<nic_name>`: comma separated list of IPs, grouped
|
||
by the name of each NIC attached to the server
|
||
* `__meta_ionos_server_servers_id`: the ID of the servers the server belongs to
|
||
* `__meta_ionos_server_state`: the execution state of the server
|
||
* `__meta_ionos_server_type`: the type of the server
|
||
|
||
```yaml
|
||
# The unique ID of the data center.
|
||
datacenter_id: <string>
|
||
|
||
# Authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information, required when using IONOS
|
||
# Cloud username and password as authentication method.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration, required when using IONOS
|
||
# Cloud token as authentication method.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The time after which the servers are refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
```
|
||
|
||
### `<kubernetes_sd_config>`
|
||
|
||
Kubernetes SD configurations allow retrieving scrape targets from
|
||
[Kubernetes'](https://kubernetes.io/) REST API and always staying synchronized with
|
||
the cluster state.
|
||
|
||
One of the following `role` types can be configured to discover targets:
|
||
|
||
#### `node`
|
||
|
||
The `node` role discovers one target per cluster node with the address defaulting
|
||
to the Kubelet's HTTP port.
|
||
The target address defaults to the first existing address of the Kubernetes
|
||
node object in the address type order of `NodeInternalIP`, `NodeExternalIP`,
|
||
`NodeLegacyHostIP`, and `NodeHostName`.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_kubernetes_node_name`: The name of the node object.
|
||
* `__meta_kubernetes_node_provider_id`: The cloud provider's name for the node object.
|
||
* `__meta_kubernetes_node_label_<labelname>`: Each label from the node object.
|
||
* `__meta_kubernetes_node_labelpresent_<labelname>`: `true` for each label from the node object.
|
||
* `__meta_kubernetes_node_annotation_<annotationname>`: Each annotation from the node object.
|
||
* `__meta_kubernetes_node_annotationpresent_<annotationname>`: `true` for each annotation from the node object.
|
||
* `__meta_kubernetes_node_address_<address_type>`: The first address for each node address type, if it exists.
|
||
|
||
In addition, the `instance` label for the node will be set to the node name
|
||
as retrieved from the API server.
|
||
|
||
#### `service`
|
||
|
||
The `service` role discovers a target for each service port for each service.
|
||
This is generally useful for blackbox monitoring of a service.
|
||
The address will be set to the Kubernetes DNS name of the service and respective
|
||
service port.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_kubernetes_namespace`: The namespace of the service object.
|
||
* `__meta_kubernetes_service_annotation_<annotationname>`: Each annotation from the service object.
|
||
* `__meta_kubernetes_service_annotationpresent_<annotationname>`: "true" for each annotation of the service object.
|
||
* `__meta_kubernetes_service_cluster_ip`: The cluster IP address of the service. (Does not apply to services of type ExternalName)
|
||
* `__meta_kubernetes_service_external_name`: The DNS name of the service. (Applies to services of type ExternalName)
|
||
* `__meta_kubernetes_service_label_<labelname>`: Each label from the service object.
|
||
* `__meta_kubernetes_service_labelpresent_<labelname>`: `true` for each label of the service object.
|
||
* `__meta_kubernetes_service_name`: The name of the service object.
|
||
* `__meta_kubernetes_service_port_name`: Name of the service port for the target.
|
||
* `__meta_kubernetes_service_port_protocol`: Protocol of the service port for the target.
|
||
* `__meta_kubernetes_service_type`: The type of the service.
|
||
|
||
#### `pod`
|
||
|
||
The `pod` role discovers all pods and exposes their containers as targets. For each declared
|
||
port of a container, a single target is generated. If a container has no specified ports,
|
||
a port-free target per container is created for manually adding a port via relabeling.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_kubernetes_namespace`: The namespace of the pod object.
|
||
* `__meta_kubernetes_pod_name`: The name of the pod object.
|
||
* `__meta_kubernetes_pod_ip`: The pod IP of the pod object.
|
||
* `__meta_kubernetes_pod_label_<labelname>`: Each label from the pod object.
|
||
* `__meta_kubernetes_pod_labelpresent_<labelname>`: `true`for each label from the pod object.
|
||
* `__meta_kubernetes_pod_annotation_<annotationname>`: Each annotation from the pod object.
|
||
* `__meta_kubernetes_pod_annotationpresent_<annotationname>`: `true` for each annotation from the pod object.
|
||
* `__meta_kubernetes_pod_container_init`: `true` if the container is an [InitContainer](https://kubernetes.io/docs/concepts/workloads/pods/init-containers/)
|
||
* `__meta_kubernetes_pod_container_name`: Name of the container the target address points to.
|
||
* `__meta_kubernetes_pod_container_port_name`: Name of the container port.
|
||
* `__meta_kubernetes_pod_container_port_number`: Number of the container port.
|
||
* `__meta_kubernetes_pod_container_port_protocol`: Protocol of the container port.
|
||
* `__meta_kubernetes_pod_ready`: Set to `true` or `false` for the pod's ready state.
|
||
* `__meta_kubernetes_pod_phase`: Set to `Pending`, `Running`, `Succeeded`, `Failed` or `Unknown`
|
||
in the [lifecycle](https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#pod-phase).
|
||
* `__meta_kubernetes_pod_node_name`: The name of the node the pod is scheduled onto.
|
||
* `__meta_kubernetes_pod_host_ip`: The current host IP of the pod object.
|
||
* `__meta_kubernetes_pod_uid`: The UID of the pod object.
|
||
* `__meta_kubernetes_pod_controller_kind`: Object kind of the pod controller.
|
||
* `__meta_kubernetes_pod_controller_name`: Name of the pod controller.
|
||
|
||
#### `endpoints`
|
||
|
||
The `endpoints` role discovers targets from listed endpoints of a service. For each endpoint
|
||
address one target is discovered per port. If the endpoint is backed by a pod, all
|
||
additional container ports of the pod, not bound to an endpoint port, are discovered as targets as well.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_kubernetes_namespace`: The namespace of the endpoints object.
|
||
* `__meta_kubernetes_endpoints_name`: The names of the endpoints object.
|
||
* For all targets discovered directly from the endpoints list (those not additionally inferred
|
||
from underlying pods), the following labels are attached:
|
||
* `__meta_kubernetes_endpoint_hostname`: Hostname of the endpoint.
|
||
* `__meta_kubernetes_endpoint_node_name`: Name of the node hosting the endpoint.
|
||
* `__meta_kubernetes_endpoint_ready`: Set to `true` or `false` for the endpoint's ready state.
|
||
* `__meta_kubernetes_endpoint_port_name`: Name of the endpoint port.
|
||
* `__meta_kubernetes_endpoint_port_protocol`: Protocol of the endpoint port.
|
||
* `__meta_kubernetes_endpoint_address_target_kind`: Kind of the endpoint address target.
|
||
* `__meta_kubernetes_endpoint_address_target_name`: Name of the endpoint address target.
|
||
* If the endpoints belong to a service, all labels of the `role: service` discovery are attached.
|
||
* For all targets backed by a pod, all labels of the `role: pod` discovery are attached.
|
||
|
||
#### `endpointslice`
|
||
|
||
The `endpointslice` role discovers targets from existing endpointslices. For each endpoint
|
||
address referenced in the endpointslice object one target is discovered. If the endpoint is backed by a pod, all
|
||
additional container ports of the pod, not bound to an endpoint port, are discovered as targets as well.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_kubernetes_namespace`: The namespace of the endpoints object.
|
||
* `__meta_kubernetes_endpointslice_name`: The name of endpointslice object.
|
||
* For all targets discovered directly from the endpointslice list (those not additionally inferred
|
||
from underlying pods), the following labels are attached:
|
||
* `__meta_kubernetes_endpointslice_address_target_kind`: Kind of the referenced object.
|
||
* `__meta_kubernetes_endpointslice_address_target_name`: Name of referenced object.
|
||
* `__meta_kubernetes_endpointslice_address_type`: The ip protocol family of the address of the target.
|
||
* `__meta_kubernetes_endpointslice_endpoint_conditions_ready`: Set to `true` or `false` for the referenced endpoint's ready state.
|
||
* `__meta_kubernetes_endpointslice_endpoint_topology_kubernetes_io_hostname`: Name of the node hosting the referenced endpoint.
|
||
* `__meta_kubernetes_endpointslice_endpoint_topology_present_kubernetes_io_hostname`: Flag that shows if the referenced object has a kubernetes.io/hostname annotation.
|
||
* `__meta_kubernetes_endpointslice_port`: Port of the referenced endpoint.
|
||
* `__meta_kubernetes_endpointslice_port_name`: Named port of the referenced endpoint.
|
||
* `__meta_kubernetes_endpointslice_port_protocol`: Protocol of the referenced endpoint.
|
||
* If the endpoints belong to a service, all labels of the `role: service` discovery are attached.
|
||
* For all targets backed by a pod, all labels of the `role: pod` discovery are attached.
|
||
|
||
#### `ingress`
|
||
|
||
The `ingress` role discovers a target for each path of each ingress.
|
||
This is generally useful for blackbox monitoring of an ingress.
|
||
The address will be set to the host specified in the ingress spec.
|
||
|
||
Available meta labels:
|
||
|
||
* `__meta_kubernetes_namespace`: The namespace of the ingress object.
|
||
* `__meta_kubernetes_ingress_name`: The name of the ingress object.
|
||
* `__meta_kubernetes_ingress_label_<labelname>`: Each label from the ingress object.
|
||
* `__meta_kubernetes_ingress_labelpresent_<labelname>`: `true` for each label from the ingress object.
|
||
* `__meta_kubernetes_ingress_annotation_<annotationname>`: Each annotation from the ingress object.
|
||
* `__meta_kubernetes_ingress_annotationpresent_<annotationname>`: `true` for each annotation from the ingress object.
|
||
* `__meta_kubernetes_ingress_class_name`: Class name from ingress spec, if present.
|
||
* `__meta_kubernetes_ingress_scheme`: Protocol scheme of ingress, `https` if TLS
|
||
config is set. Defaults to `http`.
|
||
* `__meta_kubernetes_ingress_path`: Path from ingress spec. Defaults to `/`.
|
||
|
||
See below for the configuration options for Kubernetes discovery:
|
||
|
||
```yaml
|
||
# The information to access the Kubernetes API.
|
||
|
||
# The API server addresses. If left empty, Prometheus is assumed to run inside
|
||
# of the cluster and will discover API servers automatically and use the pod's
|
||
# CA certificate and bearer token file at /var/run/secrets/kubernetes.io/serviceaccount/.
|
||
[ api_server: <host> ]
|
||
|
||
# The Kubernetes role of entities that should be discovered.
|
||
# One of endpoints, endpointslice, service, pod, node, or ingress.
|
||
role: <string>
|
||
|
||
# Optional path to a kubeconfig file.
|
||
# Note that api_server and kube_config are mutually exclusive.
|
||
[ kubeconfig_file: <filename> ]
|
||
|
||
# Optional authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth` and `authorization` options are mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional namespace discovery. If omitted, all namespaces are used.
|
||
namespaces:
|
||
own_namespace: <boolean>
|
||
names:
|
||
[ - <string> ]
|
||
|
||
# Optional label and field selectors to limit the discovery process to a subset of available resources.
|
||
# See https://kubernetes.io/docs/concepts/overview/working-with-objects/field-selectors/
|
||
# and https://kubernetes.io/docs/concepts/overview/working-with-objects/labels/ to learn more about the possible
|
||
# filters that can be used. The endpoints role supports pod, service and endpoints selectors.
|
||
# The pod role supports node selectors when configured with `attach_metadata: {node: true}`.
|
||
# Other roles only support selectors matching the role itself (e.g. node role can only contain node selectors).
|
||
|
||
# Note: When making decision about using field/label selector make sure that this
|
||
# is the best approach - it will prevent Prometheus from reusing single list/watch
|
||
# for all scrape configs. This might result in a bigger load on the Kubernetes API,
|
||
# because per each selector combination there will be additional LIST/WATCH. On the other hand,
|
||
# if you just want to monitor small subset of pods in large cluster it's recommended to use selectors.
|
||
# Decision, if selectors should be used or not depends on the particular situation.
|
||
[ selectors:
|
||
[ - role: <string>
|
||
[ label: <string> ]
|
||
[ field: <string> ] ]]
|
||
|
||
# Optional metadata to attach to discovered targets. If omitted, no additional metadata is attached.
|
||
attach_metadata:
|
||
# Attaches node metadata to discovered targets. Valid for roles: pod, endpoints, endpointslice.
|
||
# When set to true, Prometheus must have permissions to get Nodes.
|
||
[ node: <boolean> | default = false ]
|
||
```
|
||
|
||
See [this example Prometheus configuration file](/documentation/examples/prometheus-kubernetes.yml)
|
||
for a detailed example of configuring Prometheus for Kubernetes.
|
||
|
||
You may wish to check out the 3rd party [Prometheus Operator](https://github.com/coreos/prometheus-operator),
|
||
which automates the Prometheus setup on top of Kubernetes.
|
||
|
||
### `<kuma_sd_config>`
|
||
|
||
Kuma SD configurations allow retrieving scrape target from the [Kuma](https://kuma.io) control plane.
|
||
|
||
This SD discovers "monitoring assignments" based on Kuma [Dataplane Proxies](https://kuma.io/docs/latest/documentation/dps-and-data-model),
|
||
via the MADS v1 (Monitoring Assignment Discovery Service) xDS API, and will create a target for each proxy
|
||
inside a Prometheus-enabled mesh.
|
||
|
||
The following meta labels are available for each target:
|
||
|
||
* `__meta_kuma_mesh`: the name of the proxy's Mesh
|
||
* `__meta_kuma_dataplane`: the name of the proxy
|
||
* `__meta_kuma_service`: the name of the proxy's associated Service
|
||
* `__meta_kuma_label_<tagname>`: each tag of the proxy
|
||
|
||
See below for the configuration options for Kuma MonitoringAssignment discovery:
|
||
|
||
```yaml
|
||
# Address of the Kuma Control Plane's MADS xDS server.
|
||
server: <string>
|
||
|
||
# The time to wait between polling update requests.
|
||
[ refresh_interval: <duration> | default = 30s ]
|
||
|
||
# The time after which the monitoring assignments are refreshed.
|
||
[ fetch_timeout: <duration> | default = 2m ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Authentication information used to authenticate to the Docker daemon.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional the `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials with the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
```
|
||
|
||
The [relabeling phase](#relabel_config) is the preferred and more powerful way
|
||
to filter proxies and user-defined tags.
|
||
|
||
### `<lightsail_sd_config>`
|
||
|
||
Lightsail SD configurations allow retrieving scrape targets from [AWS Lightsail](https://aws.amazon.com/lightsail/)
|
||
instances. The private IP address is used by default, but may be changed to
|
||
the public IP address with relabeling.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_lightsail_availability_zone`: the availability zone in which the instance is running
|
||
* `__meta_lightsail_blueprint_id`: the Lightsail blueprint ID
|
||
* `__meta_lightsail_bundle_id`: the Lightsail bundle ID
|
||
* `__meta_lightsail_instance_name`: the name of the Lightsail instance
|
||
* `__meta_lightsail_instance_state`: the state of the Lightsail instance
|
||
* `__meta_lightsail_instance_support_code`: the support code of the Lightsail instance
|
||
* `__meta_lightsail_ipv6_addresses`: comma separated list of IPv6 addresses assigned to the instance's network interfaces, if present
|
||
* `__meta_lightsail_private_ip`: the private IP address of the instance
|
||
* `__meta_lightsail_public_ip`: the public IP address of the instance, if available
|
||
* `__meta_lightsail_tag_<tagkey>`: each tag value of the instance
|
||
|
||
See below for the configuration options for Lightsail discovery:
|
||
|
||
```yaml
|
||
# The information to access the Lightsail API.
|
||
|
||
# The AWS region. If blank, the region from the instance metadata is used.
|
||
[ region: <string> ]
|
||
|
||
# Custom endpoint to be used.
|
||
[ endpoint: <string> ]
|
||
|
||
# The AWS API keys. If blank, the environment variables `AWS_ACCESS_KEY_ID`
|
||
# and `AWS_SECRET_ACCESS_KEY` are used.
|
||
[ access_key: <string> ]
|
||
[ secret_key: <secret> ]
|
||
# Named AWS profile used to connect to the API.
|
||
[ profile: <string> ]
|
||
|
||
# AWS Role ARN, an alternative to using AWS API keys.
|
||
[ role_arn: <string> ]
|
||
|
||
# Refresh interval to re-read the instance list.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# The port to scrape metrics from. If using the public IP address, this must
|
||
# instead be specified in the relabeling rule.
|
||
[ port: <int> | default = 80 ]
|
||
```
|
||
|
||
### `<linode_sd_config>`
|
||
|
||
Linode SD configurations allow retrieving scrape targets from [Linode's](https://www.linode.com/)
|
||
Linode APIv4.
|
||
This service discovery uses the public IPv4 address by default, by that can be
|
||
changed with relabelling, as demonstrated in [the Prometheus linode-sd
|
||
configuration file](/documentation/examples/prometheus-linode.yml).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_linode_instance_id`: the id of the linode instance
|
||
* `__meta_linode_instance_label`: the label of the linode instance
|
||
* `__meta_linode_image`: the slug of the linode instance's image
|
||
* `__meta_linode_private_ipv4`: the private IPv4 of the linode instance
|
||
* `__meta_linode_public_ipv4`: the public IPv4 of the linode instance
|
||
* `__meta_linode_public_ipv6`: the public IPv6 of the linode instance
|
||
* `__meta_linode_region`: the region of the linode instance
|
||
* `__meta_linode_type`: the type of the linode instance
|
||
* `__meta_linode_status`: the status of the linode instance
|
||
* `__meta_linode_tags`: a list of tags of the linode instance joined by the tag separator
|
||
* `__meta_linode_group`: the display group a linode instance is a member of
|
||
* `__meta_linode_hypervisor`: the virtualization software powering the linode instance
|
||
* `__meta_linode_backups`: the backup service status of the linode instance
|
||
* `__meta_linode_specs_disk_bytes`: the amount of storage space the linode instance has access to
|
||
* `__meta_linode_specs_memory_bytes`: the amount of RAM the linode instance has access to
|
||
* `__meta_linode_specs_vcpus`: the number of VCPUS this linode has access to
|
||
* `__meta_linode_specs_transfer_bytes`: the amount of network transfer the linode instance is allotted each month
|
||
* `__meta_linode_extra_ips`: a list of all extra IPv4 addresses assigned to the linode instance joined by the tag separator
|
||
|
||
```yaml
|
||
# Authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
# Note: Linode APIv4 Token must be created with scopes: 'linodes:read_only', 'ips:read_only', and 'events:read_only'
|
||
|
||
# Optional HTTP basic authentication information, not currently supported by Linode APIv4.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional the `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials with the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The string by which Linode Instance tags are joined into the tag label.
|
||
[ tag_separator: <string> | default = , ]
|
||
|
||
# The time after which the linode instances are refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
```
|
||
|
||
### `<marathon_sd_config>`
|
||
|
||
Marathon SD configurations allow retrieving scrape targets using the
|
||
[Marathon](https://mesosphere.github.io/marathon/) REST API. Prometheus
|
||
will periodically check the REST endpoint for currently running tasks and
|
||
create a target group for every app that has at least one healthy task.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_marathon_app`: the name of the app (with slashes replaced by dashes)
|
||
* `__meta_marathon_image`: the name of the Docker image used (if available)
|
||
* `__meta_marathon_task`: the ID of the Mesos task
|
||
* `__meta_marathon_app_label_<labelname>`: any Marathon labels attached to the app
|
||
* `__meta_marathon_port_definition_label_<labelname>`: the port definition labels
|
||
* `__meta_marathon_port_mapping_label_<labelname>`: the port mapping labels
|
||
* `__meta_marathon_port_index`: the port index number (e.g. `1` for `PORT1`)
|
||
|
||
See below for the configuration options for Marathon discovery:
|
||
|
||
```yaml
|
||
# List of URLs to be used to contact Marathon servers.
|
||
# You need to provide at least one server URL.
|
||
servers:
|
||
- <string>
|
||
|
||
# Polling interval
|
||
[ refresh_interval: <duration> | default = 30s ]
|
||
|
||
# Optional authentication information for token-based authentication
|
||
# https://docs.mesosphere.com/1.11/security/ent/iam-api/#passing-an-authentication-token
|
||
# It is mutually exclusive with `auth_token_file` and other authentication mechanisms.
|
||
[ auth_token: <secret> ]
|
||
|
||
# Optional authentication information for token-based authentication
|
||
# https://docs.mesosphere.com/1.11/security/ent/iam-api/#passing-an-authentication-token
|
||
# It is mutually exclusive with `auth_token` and other authentication mechanisms.
|
||
[ auth_token_file: <filename> ]
|
||
|
||
# Sets the `Authorization` header on every request with the
|
||
# configured username and password.
|
||
# This is mutually exclusive with other authentication mechanisms.
|
||
# password and password_file are mutually exclusive.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
# NOTE: The current version of DC/OS marathon (v1.11.0) does not support
|
||
# standard `Authentication` header, use `auth_token` or `auth_token_file`
|
||
# instead.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration for connecting to marathon servers
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
```
|
||
|
||
By default every app listed in Marathon will be scraped by Prometheus. If not all
|
||
of your services provide Prometheus metrics, you can use a Marathon label and
|
||
Prometheus relabeling to control which instances will actually be scraped.
|
||
See [the Prometheus marathon-sd configuration file](/documentation/examples/prometheus-marathon.yml)
|
||
for a practical example on how to set up your Marathon app and your Prometheus
|
||
configuration.
|
||
|
||
By default, all apps will show up as a single job in Prometheus (the one specified
|
||
in the configuration file), which can also be changed using relabeling.
|
||
|
||
### `<nerve_sd_config>`
|
||
|
||
Nerve SD configurations allow retrieving scrape targets from [AirBnB's Nerve]
|
||
(https://github.com/airbnb/nerve) which are stored in
|
||
[Zookeeper](https://zookeeper.apache.org/).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_nerve_path`: the full path to the endpoint node in Zookeeper
|
||
* `__meta_nerve_endpoint_host`: the host of the endpoint
|
||
* `__meta_nerve_endpoint_port`: the port of the endpoint
|
||
* `__meta_nerve_endpoint_name`: the name of the endpoint
|
||
|
||
```yaml
|
||
# The Zookeeper servers.
|
||
servers:
|
||
- <host>
|
||
# Paths can point to a single service, or the root of a tree of services.
|
||
paths:
|
||
- <string>
|
||
[ timeout: <duration> | default = 10s ]
|
||
```
|
||
### `<nomad_sd_config>`
|
||
|
||
Nomad SD configurations allow retrieving scrape targets from [Nomad's](https://www.nomadproject.io/)
|
||
Service API.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_nomad_address`: the service address of the target
|
||
* `__meta_nomad_dc`: the datacenter name for the target
|
||
* `__meta_nomad_namespace`: the namespace of the target
|
||
* `__meta_nomad_node_id`: the node name defined for the target
|
||
* `__meta_nomad_service`: the name of the service the target belongs to
|
||
* `__meta_nomad_service_address`: the service address of the target
|
||
* `__meta_nomad_service_id`: the service ID of the target
|
||
* `__meta_nomad_service_port`: the service port of the target
|
||
* `__meta_nomad_tags`: the list of tags of the target joined by the tag separator
|
||
|
||
```yaml
|
||
# The information to access the Nomad API. It is to be defined
|
||
# as the Nomad documentation requires.
|
||
[ allow_stale: <boolean> | default = true ]
|
||
[ datacenter: <string> ]
|
||
[ namespace: <string> | default = default ]
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
[ region: <string> | default = global ]
|
||
[ server: <host> ]
|
||
[ tag_separator: <string> | default = ,]
|
||
|
||
# Authentication information used to authenticate to the nomad server.
|
||
# Note that `basic_auth`, `authorization` and `oauth2` options are
|
||
# mutually exclusive.
|
||
# `password` and `password_file` are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<serverset_sd_config>`
|
||
|
||
Serverset SD configurations allow retrieving scrape targets from [Serversets]
|
||
(https://github.com/twitter/finagle/tree/master/finagle-serversets) which are
|
||
stored in [Zookeeper](https://zookeeper.apache.org/). Serversets are commonly
|
||
used by [Finagle](https://twitter.github.io/finagle/) and
|
||
[Aurora](https://aurora.apache.org/).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_serverset_path`: the full path to the serverset member node in Zookeeper
|
||
* `__meta_serverset_endpoint_host`: the host of the default endpoint
|
||
* `__meta_serverset_endpoint_port`: the port of the default endpoint
|
||
* `__meta_serverset_endpoint_host_<endpoint>`: the host of the given endpoint
|
||
* `__meta_serverset_endpoint_port_<endpoint>`: the port of the given endpoint
|
||
* `__meta_serverset_shard`: the shard number of the member
|
||
* `__meta_serverset_status`: the status of the member
|
||
|
||
```yaml
|
||
# The Zookeeper servers.
|
||
servers:
|
||
- <host>
|
||
# Paths can point to a single serverset, or the root of a tree of serversets.
|
||
paths:
|
||
- <string>
|
||
[ timeout: <duration> | default = 10s ]
|
||
```
|
||
|
||
Serverset data must be in the JSON format, the Thrift format is not currently supported.
|
||
|
||
### `<triton_sd_config>`
|
||
|
||
[Triton](https://github.com/joyent/triton) SD configurations allow retrieving
|
||
scrape targets from [Container Monitor](https://github.com/joyent/rfd/blob/master/rfd/0027/README.md)
|
||
discovery endpoints.
|
||
|
||
One of the following `<triton_role>` types can be configured to discover targets:
|
||
|
||
#### `container`
|
||
|
||
The `container` role discovers one target per "virtual machine" owned by the `account`.
|
||
These are SmartOS zones or lx/KVM/bhyve branded zones.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_triton_groups`: the list of groups belonging to the target joined by a comma separator
|
||
* `__meta_triton_machine_alias`: the alias of the target container
|
||
* `__meta_triton_machine_brand`: the brand of the target container
|
||
* `__meta_triton_machine_id`: the UUID of the target container
|
||
* `__meta_triton_machine_image`: the target container's image type
|
||
* `__meta_triton_server_id`: the server UUID the target container is running on
|
||
|
||
#### `cn`
|
||
|
||
The `cn` role discovers one target for per compute node (also known as "server" or "global zone") making up the Triton infrastructure.
|
||
The `account` must be a Triton operator and is currently required to own at least one `container`.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_triton_machine_alias`: the hostname of the target (requires triton-cmon 1.7.0 or newer)
|
||
* `__meta_triton_machine_id`: the UUID of the target
|
||
|
||
See below for the configuration options for Triton discovery:
|
||
|
||
```yaml
|
||
# The information to access the Triton discovery API.
|
||
|
||
# The account to use for discovering new targets.
|
||
account: <string>
|
||
|
||
# The type of targets to discover, can be set to:
|
||
# * "container" to discover virtual machines (SmartOS zones, lx/KVM/bhyve branded zones) running on Triton
|
||
# * "cn" to discover compute nodes (servers/global zones) making up the Triton infrastructure
|
||
[ role : <string> | default = "container" ]
|
||
|
||
# The DNS suffix which should be applied to target.
|
||
dns_suffix: <string>
|
||
|
||
# The Triton discovery endpoint (e.g. 'cmon.us-east-3b.triton.zone'). This is
|
||
# often the same value as dns_suffix.
|
||
endpoint: <string>
|
||
|
||
# A list of groups for which targets are retrieved, only supported when `role` == `container`.
|
||
# If omitted all containers owned by the requesting account are scraped.
|
||
groups:
|
||
[ - <string> ... ]
|
||
|
||
# The port to use for discovery and metric scraping.
|
||
[ port: <int> | default = 9163 ]
|
||
|
||
# The interval which should be used for refreshing targets.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# The Triton discovery API version.
|
||
[ version: <int> | default = 1 ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<eureka_sd_config>`
|
||
|
||
Eureka SD configurations allow retrieving scrape targets using the
|
||
[Eureka](https://github.com/Netflix/eureka) REST API. Prometheus
|
||
will periodically check the REST endpoint and
|
||
create a target for every app instance.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_eureka_app_name`: the name of the app
|
||
* `__meta_eureka_app_instance_id`: the ID of the app instance
|
||
* `__meta_eureka_app_instance_hostname`: the hostname of the instance
|
||
* `__meta_eureka_app_instance_homepage_url`: the homepage url of the app instance
|
||
* `__meta_eureka_app_instance_statuspage_url`: the status page url of the app instance
|
||
* `__meta_eureka_app_instance_healthcheck_url`: the health check url of the app instance
|
||
* `__meta_eureka_app_instance_ip_addr`: the IP address of the app instance
|
||
* `__meta_eureka_app_instance_vip_address`: the VIP address of the app instance
|
||
* `__meta_eureka_app_instance_secure_vip_address`: the secure VIP address of the app instance
|
||
* `__meta_eureka_app_instance_status`: the status of the app instance
|
||
* `__meta_eureka_app_instance_port`: the port of the app instance
|
||
* `__meta_eureka_app_instance_port_enabled`: the port enabled of the app instance
|
||
* `__meta_eureka_app_instance_secure_port`: the secure port address of the app instance
|
||
* `__meta_eureka_app_instance_secure_port_enabled`: the secure port of the app instance
|
||
* `__meta_eureka_app_instance_country_id`: the country ID of the app instance
|
||
* `__meta_eureka_app_instance_metadata_<metadataname>`: app instance metadata
|
||
* `__meta_eureka_app_instance_datacenterinfo_name`: the datacenter name of the app instance
|
||
* `__meta_eureka_app_instance_datacenterinfo_<metadataname>`: the datacenter metadata
|
||
|
||
See below for the configuration options for Eureka discovery:
|
||
|
||
```yaml
|
||
# The URL to connect to the Eureka server.
|
||
server: <string>
|
||
|
||
# Sets the `Authorization` header on every request with the
|
||
# configured username and password.
|
||
# password and password_file are mutually exclusive.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configures the scrape request's TLS settings.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# Refresh interval to re-read the app instance list.
|
||
[ refresh_interval: <duration> | default = 30s ]
|
||
```
|
||
|
||
See [the Prometheus eureka-sd configuration file](/documentation/examples/prometheus-eureka.yml)
|
||
for a practical example on how to set up your Eureka app and your Prometheus
|
||
configuration.
|
||
|
||
### `<scaleway_sd_config>`
|
||
|
||
Scaleway SD configurations allow retrieving scrape targets from [Scaleway instances](https://www.scaleway.com/en/virtual-instances/) and [baremetal services](https://www.scaleway.com/en/bare-metal-servers/).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
#### Instance role
|
||
|
||
|
||
* `__meta_scaleway_instance_boot_type`: the boot type of the server
|
||
* `__meta_scaleway_instance_hostname`: the hostname of the server
|
||
* `__meta_scaleway_instance_id`: the ID of the server
|
||
* `__meta_scaleway_instance_image_arch`: the arch of the server image
|
||
* `__meta_scaleway_instance_image_id`: the ID of the server image
|
||
* `__meta_scaleway_instance_image_name`: the name of the server image
|
||
* `__meta_scaleway_instance_location_cluster_id`: the cluster ID of the server location
|
||
* `__meta_scaleway_instance_location_hypervisor_id`: the hypervisor ID of the server location
|
||
* `__meta_scaleway_instance_location_node_id`: the node ID of the server location
|
||
* `__meta_scaleway_instance_name`: name of the server
|
||
* `__meta_scaleway_instance_organization_id`: the organization of the server
|
||
* `__meta_scaleway_instance_private_ipv4`: the private IPv4 address of the server
|
||
* `__meta_scaleway_instance_project_id`: project id of the server
|
||
* `__meta_scaleway_instance_public_ipv4`: the public IPv4 address of the server
|
||
* `__meta_scaleway_instance_public_ipv6`: the public IPv6 address of the server
|
||
* `__meta_scaleway_instance_region`: the region of the server
|
||
* `__meta_scaleway_instance_security_group_id`: the ID of the security group of the server
|
||
* `__meta_scaleway_instance_security_group_name`: the name of the security group of the server
|
||
* `__meta_scaleway_instance_status`: status of the server
|
||
* `__meta_scaleway_instance_tags`: the list of tags of the server joined by the tag separator
|
||
* `__meta_scaleway_instance_type`: commercial type of the server
|
||
* `__meta_scaleway_instance_zone`: the zone of the server (ex: `fr-par-1`, complete list [here](https://developers.scaleway.com/en/products/instance/api/#introduction))
|
||
|
||
This role uses the private IPv4 address by default. This can be
|
||
changed with relabelling, as demonstrated in [the Prometheus scaleway-sd
|
||
configuration file](/documentation/examples/prometheus-scaleway.yml).
|
||
|
||
#### Baremetal role
|
||
|
||
* `__meta_scaleway_baremetal_id`: the ID of the server
|
||
* `__meta_scaleway_baremetal_public_ipv4`: the public IPv4 address of the server
|
||
* `__meta_scaleway_baremetal_public_ipv6`: the public IPv6 address of the server
|
||
* `__meta_scaleway_baremetal_name`: the name of the server
|
||
* `__meta_scaleway_baremetal_os_name`: the name of the operating system of the server
|
||
* `__meta_scaleway_baremetal_os_version`: the version of the operating system of the server
|
||
* `__meta_scaleway_baremetal_project_id`: the project ID of the server
|
||
* `__meta_scaleway_baremetal_status`: the status of the server
|
||
* `__meta_scaleway_baremetal_tags`: the list of tags of the server joined by the tag separator
|
||
* `__meta_scaleway_baremetal_type`: the commercial type of the server
|
||
* `__meta_scaleway_baremetal_zone`: the zone of the server (ex: `fr-par-1`, complete list [here](https://developers.scaleway.com/en/products/instance/api/#introduction))
|
||
|
||
This role uses the public IPv4 address by default. This can be
|
||
changed with relabelling, as demonstrated in [the Prometheus scaleway-sd
|
||
configuration file](/documentation/examples/prometheus-scaleway.yml).
|
||
|
||
See below for the configuration options for Scaleway discovery:
|
||
|
||
```yaml
|
||
# Access key to use. https://console.scaleway.com/project/credentials
|
||
access_key: <string>
|
||
|
||
# Secret key to use when listing targets. https://console.scaleway.com/project/credentials
|
||
# It is mutually exclusive with `secret_key_file`.
|
||
[ secret_key: <secret> ]
|
||
|
||
# Sets the secret key with the credentials read from the configured file.
|
||
# It is mutually exclusive with `secret_key`.
|
||
[ secret_key_file: <filename> ]
|
||
|
||
# Project ID of the targets.
|
||
project_id: <string>
|
||
|
||
# Role of the targets to retrieve. Must be `instance` or `baremetal`.
|
||
role: <string>
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# API URL to use when doing the server listing requests.
|
||
[ api_url: <string> | default = "https://api.scaleway.com" ]
|
||
|
||
# Zone is the availability zone of your targets (e.g. fr-par-1).
|
||
[ zone: <string> | default = fr-par-1 ]
|
||
|
||
# NameFilter specify a name filter (works as a LIKE) to apply on the server listing request.
|
||
[ name_filter: <string> ]
|
||
|
||
# TagsFilter specify a tag filter (a server needs to have all defined tags to be listed) to apply on the server listing request.
|
||
tags_filter:
|
||
[ - <string> ]
|
||
|
||
# Refresh interval to re-read the targets list.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<uyuni_sd_config>`
|
||
|
||
Uyuni SD configurations allow retrieving scrape targets from managed systems
|
||
via [Uyuni](https://www.uyuni-project.org/) API.
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_uyuni_endpoint_name`: the name of the application endpoint
|
||
* `__meta_uyuni_exporter`: the exporter exposing metrics for the target
|
||
* `__meta_uyuni_groups`: the system groups of the target
|
||
* `__meta_uyuni_metrics_path`: metrics path for the target
|
||
* `__meta_uyuni_minion_hostname`: hostname of the Uyuni client
|
||
* `__meta_uyuni_primary_fqdn`: primary FQDN of the Uyuni client
|
||
* `__meta_uyuni_proxy_module`: the module name if _Exporter Exporter_ proxy is
|
||
configured for the target
|
||
* `__meta_uyuni_scheme`: the protocol scheme used for requests
|
||
* `__meta_uyuni_system_id`: the system ID of the client
|
||
|
||
See below for the configuration options for Uyuni discovery:
|
||
|
||
```yaml
|
||
# The URL to connect to the Uyuni server.
|
||
server: <string>
|
||
|
||
# Credentials are used to authenticate the requests to Uyuni API.
|
||
username: <string>
|
||
password: <secret>
|
||
|
||
# The entitlement string to filter eligible systems.
|
||
[ entitlement: <string> | default = monitoring_entitled ]
|
||
|
||
# The string by which Uyuni group names are joined into the groups label.
|
||
[ separator: <string> | default = , ]
|
||
|
||
# Refresh interval to re-read the managed targets list.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
|
||
# Optional HTTP basic authentication information, currently not supported by Uyuni.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration, currently not supported by Uyuni.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration, currently not supported by Uyuni.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
See [the Prometheus uyuni-sd configuration file](/documentation/examples/prometheus-uyuni.yml)
|
||
for a practical example on how to set up Uyuni Prometheus configuration.
|
||
|
||
### `<vultr_sd_config>`
|
||
|
||
Vultr SD configurations allow retrieving scrape targets from [Vultr](https://www.vultr.com/).
|
||
|
||
This service discovery uses the main IPv4 address by default, which that be
|
||
changed with relabelling, as demonstrated in [the Prometheus vultr-sd
|
||
configuration file](/documentation/examples/prometheus-vultr.yml).
|
||
|
||
The following meta labels are available on targets during [relabeling](#relabel_config):
|
||
|
||
* `__meta_vultr_instance_id` : A unique ID for the vultr Instance.
|
||
* `__meta_vultr_instance_label` : The user-supplied label for this instance.
|
||
* `__meta_vultr_instance_os` : The Operating System name.
|
||
* `__meta_vultr_instance_os_id` : The Operating System id used by this instance.
|
||
* `__meta_vultr_instance_region` : The Region id where the Instance is located.
|
||
* `__meta_vultr_instance_plan` : A unique ID for the Plan.
|
||
* `__meta_vultr_instance_main_ip` : The main IPv4 address.
|
||
* `__meta_vultr_instance_internal_ip` : The private IP address.
|
||
* `__meta_vultr_instance_main_ipv6` : The main IPv6 address.
|
||
* `__meta_vultr_instance_features` : List of features that are available to the instance.
|
||
* `__meta_vultr_instance_tags` : List of tags associated with the instance.
|
||
* `__meta_vultr_instance_hostname` : The hostname for this instance.
|
||
* `__meta_vultr_instance_server_status` : The server health status.
|
||
* `__meta_vultr_instance_vcpu_count` : Number of vCPUs.
|
||
* `__meta_vultr_instance_ram_mb` : The amount of RAM in MB.
|
||
* `__meta_vultr_instance_disk_gb` : The size of the disk in GB.
|
||
* `__meta_vultr_instance_allowed_bandwidth_gb` : Monthly bandwidth quota in GB.
|
||
|
||
```yaml
|
||
# Authentication information used to authenticate to the API server.
|
||
# Note that `basic_auth` and `authorization` options are
|
||
# mutually exclusive.
|
||
# password and password_file are mutually exclusive.
|
||
|
||
# Optional HTTP basic authentication information, not currently supported by Vultr.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# The port to scrape metrics from.
|
||
[ port: <int> | default = 80 ]
|
||
|
||
# The time after which the instances are refreshed.
|
||
[ refresh_interval: <duration> | default = 60s ]
|
||
```
|
||
|
||
|
||
### `<static_config>`
|
||
|
||
A `static_config` allows specifying a list of targets and a common label set
|
||
for them. It is the canonical way to specify static targets in a scrape
|
||
configuration.
|
||
|
||
```yaml
|
||
# The targets specified by the static config.
|
||
targets:
|
||
[ - '<host>' ]
|
||
|
||
# Labels assigned to all metrics scraped from the targets.
|
||
labels:
|
||
[ <labelname>: <labelvalue> ... ]
|
||
```
|
||
|
||
### `<relabel_config>`
|
||
|
||
Relabeling is a powerful tool to dynamically rewrite the label set of a target before
|
||
it gets scraped. Multiple relabeling steps can be configured per scrape configuration.
|
||
They are applied to the label set of each target in order of their appearance
|
||
in the configuration file.
|
||
|
||
Initially, aside from the configured per-target labels, a target's `job`
|
||
label is set to the `job_name` value of the respective scrape configuration.
|
||
The `__address__` label is set to the `<host>:<port>` address of the target.
|
||
After relabeling, the `instance` label is set to the value of `__address__` by default if
|
||
it was not set during relabeling. The `__scheme__` and `__metrics_path__` labels
|
||
are set to the scheme and metrics path of the target respectively. The `__param_<name>`
|
||
label is set to the value of the first passed URL parameter called `<name>`.
|
||
|
||
The `__scrape_interval__` and `__scrape_timeout__` labels are set to the target's
|
||
interval and timeout. This is **experimental** and could change in the future.
|
||
|
||
Additional labels prefixed with `__meta_` may be available during the
|
||
relabeling phase. They are set by the service discovery mechanism that provided
|
||
the target and vary between mechanisms.
|
||
|
||
Labels starting with `__` will be removed from the label set after target
|
||
relabeling is completed.
|
||
|
||
If a relabeling step needs to store a label value only temporarily (as the
|
||
input to a subsequent relabeling step), use the `__tmp` label name prefix. This
|
||
prefix is guaranteed to never be used by Prometheus itself.
|
||
|
||
```yaml
|
||
# The source labels select values from existing labels. Their content is concatenated
|
||
# using the configured separator and matched against the configured regular expression
|
||
# for the replace, keep, and drop actions.
|
||
[ source_labels: '[' <labelname> [, ...] ']' ]
|
||
|
||
# Separator placed between concatenated source label values.
|
||
[ separator: <string> | default = ; ]
|
||
|
||
# Label to which the resulting value is written in a replace action.
|
||
# It is mandatory for replace actions. Regex capture groups are available.
|
||
[ target_label: <labelname> ]
|
||
|
||
# Regular expression against which the extracted value is matched.
|
||
[ regex: <regex> | default = (.*) ]
|
||
|
||
# Modulus to take of the hash of the source label values.
|
||
[ modulus: <int> ]
|
||
|
||
# Replacement value against which a regex replace is performed if the
|
||
# regular expression matches. Regex capture groups are available.
|
||
[ replacement: <string> | default = $1 ]
|
||
|
||
# Action to perform based on regex matching.
|
||
[ action: <relabel_action> | default = replace ]
|
||
```
|
||
|
||
`<regex>` is any valid
|
||
[RE2 regular expression](https://github.com/google/re2/wiki/Syntax). It is
|
||
required for the `replace`, `keep`, `drop`, `labelmap`,`labeldrop` and `labelkeep` actions. The regex is
|
||
anchored on both ends. To un-anchor the regex, use `.*<regex>.*`.
|
||
|
||
`<relabel_action>` determines the relabeling action to take:
|
||
|
||
* `replace`: Match `regex` against the concatenated `source_labels`. Then, set
|
||
`target_label` to `replacement`, with match group references
|
||
(`${1}`, `${2}`, ...) in `replacement` substituted by their value. If `regex`
|
||
does not match, no replacement takes place.
|
||
* `lowercase`: Maps the concatenated `source_labels` to their lower case.
|
||
* `uppercase`: Maps the concatenated `source_labels` to their upper case.
|
||
* `keep`: Drop targets for which `regex` does not match the concatenated `source_labels`.
|
||
* `drop`: Drop targets for which `regex` matches the concatenated `source_labels`.
|
||
* `hashmod`: Set `target_label` to the `modulus` of a hash of the concatenated `source_labels`.
|
||
* `labelmap`: Match `regex` against all source label names, not just those specified in `source_labels`. Then
|
||
copy the values of the matching labels to label names given by `replacement` with match
|
||
group references (`${1}`, `${2}`, ...) in `replacement` substituted by their value.
|
||
* `labeldrop`: Match `regex` against all label names. Any label that matches will be
|
||
removed from the set of labels.
|
||
* `labelkeep`: Match `regex` against all label names. Any label that does not match will be
|
||
removed from the set of labels.
|
||
|
||
Care must be taken with `labeldrop` and `labelkeep` to ensure that metrics are
|
||
still uniquely labeled once the labels are removed.
|
||
|
||
### `<metric_relabel_configs>`
|
||
|
||
Metric relabeling is applied to samples as the last step before ingestion. It
|
||
has the same configuration format and actions as target relabeling. Metric
|
||
relabeling does not apply to automatically generated timeseries such as `up`.
|
||
|
||
One use for this is to exclude time series that are too expensive to ingest.
|
||
|
||
### `<alert_relabel_configs>`
|
||
|
||
Alert relabeling is applied to alerts before they are sent to the Alertmanager.
|
||
It has the same configuration format and actions as target relabeling. Alert
|
||
relabeling is applied after external labels.
|
||
|
||
One use for this is ensuring a HA pair of Prometheus servers with different
|
||
external labels send identical alerts.
|
||
|
||
### `<alertmanager_config>`
|
||
|
||
An `alertmanager_config` section specifies Alertmanager instances the Prometheus
|
||
server sends alerts to. It also provides parameters to configure how to
|
||
communicate with these Alertmanagers.
|
||
|
||
Alertmanagers may be statically configured via the `static_configs` parameter or
|
||
dynamically discovered using one of the supported service-discovery mechanisms.
|
||
|
||
Additionally, `relabel_configs` allow selecting Alertmanagers from discovered
|
||
entities and provide advanced modifications to the used API path, which is exposed
|
||
through the `__alerts_path__` label.
|
||
|
||
```yaml
|
||
# Per-target Alertmanager timeout when pushing alerts.
|
||
[ timeout: <duration> | default = 10s ]
|
||
|
||
# The api version of Alertmanager.
|
||
[ api_version: <string> | default = v2 ]
|
||
|
||
# Prefix for the HTTP path alerts are pushed to.
|
||
[ path_prefix: <path> | default = / ]
|
||
|
||
# Configures the protocol scheme used for requests.
|
||
[ scheme: <scheme> | default = http ]
|
||
|
||
# Sets the `Authorization` header on every request with the
|
||
# configured username and password.
|
||
# password and password_file are mutually exclusive.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configures the scrape request's TLS settings.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# List of Azure service discovery configurations.
|
||
azure_sd_configs:
|
||
[ - <azure_sd_config> ... ]
|
||
|
||
# List of Consul service discovery configurations.
|
||
consul_sd_configs:
|
||
[ - <consul_sd_config> ... ]
|
||
|
||
# List of DNS service discovery configurations.
|
||
dns_sd_configs:
|
||
[ - <dns_sd_config> ... ]
|
||
|
||
# List of EC2 service discovery configurations.
|
||
ec2_sd_configs:
|
||
[ - <ec2_sd_config> ... ]
|
||
|
||
# List of Eureka service discovery configurations.
|
||
eureka_sd_configs:
|
||
[ - <eureka_sd_config> ... ]
|
||
|
||
# List of file service discovery configurations.
|
||
file_sd_configs:
|
||
[ - <file_sd_config> ... ]
|
||
|
||
# List of DigitalOcean service discovery configurations.
|
||
digitalocean_sd_configs:
|
||
[ - <digitalocean_sd_config> ... ]
|
||
|
||
# List of Docker service discovery configurations.
|
||
docker_sd_configs:
|
||
[ - <docker_sd_config> ... ]
|
||
|
||
# List of Docker Swarm service discovery configurations.
|
||
dockerswarm_sd_configs:
|
||
[ - <dockerswarm_sd_config> ... ]
|
||
|
||
# List of GCE service discovery configurations.
|
||
gce_sd_configs:
|
||
[ - <gce_sd_config> ... ]
|
||
|
||
# List of Hetzner service discovery configurations.
|
||
hetzner_sd_configs:
|
||
[ - <hetzner_sd_config> ... ]
|
||
|
||
# List of HTTP service discovery configurations.
|
||
http_sd_configs:
|
||
[ - <http_sd_config> ... ]
|
||
|
||
# List of IONOS service discovery configurations.
|
||
ionos_sd_configs:
|
||
[ - <ionos_sd_config> ... ]
|
||
|
||
# List of Kubernetes service discovery configurations.
|
||
kubernetes_sd_configs:
|
||
[ - <kubernetes_sd_config> ... ]
|
||
|
||
# List of Lightsail service discovery configurations.
|
||
lightsail_sd_configs:
|
||
[ - <lightsail_sd_config> ... ]
|
||
|
||
# List of Linode service discovery configurations.
|
||
linode_sd_configs:
|
||
[ - <linode_sd_config> ... ]
|
||
|
||
# List of Marathon service discovery configurations.
|
||
marathon_sd_configs:
|
||
[ - <marathon_sd_config> ... ]
|
||
|
||
# List of AirBnB's Nerve service discovery configurations.
|
||
nerve_sd_configs:
|
||
[ - <nerve_sd_config> ... ]
|
||
|
||
# List of Nomad service discovery configurations.
|
||
nomad_sd_configs:
|
||
[ - <nomad_sd_config> ... ]
|
||
|
||
# List of OpenStack service discovery configurations.
|
||
openstack_sd_configs:
|
||
[ - <openstack_sd_config> ... ]
|
||
|
||
# List of PuppetDB service discovery configurations.
|
||
puppetdb_sd_configs:
|
||
[ - <puppetdb_sd_config> ... ]
|
||
|
||
# List of Scaleway service discovery configurations.
|
||
scaleway_sd_configs:
|
||
[ - <scaleway_sd_config> ... ]
|
||
|
||
# List of Zookeeper Serverset service discovery configurations.
|
||
serverset_sd_configs:
|
||
[ - <serverset_sd_config> ... ]
|
||
|
||
# List of Triton service discovery configurations.
|
||
triton_sd_configs:
|
||
[ - <triton_sd_config> ... ]
|
||
|
||
# List of Uyuni service discovery configurations.
|
||
uyuni_sd_configs:
|
||
[ - <uyuni_sd_config> ... ]
|
||
|
||
# List of Vultr service discovery configurations.
|
||
vultr_sd_configs:
|
||
[ - <vultr_sd_config> ... ]
|
||
|
||
# List of labeled statically configured Alertmanagers.
|
||
static_configs:
|
||
[ - <static_config> ... ]
|
||
|
||
# List of Alertmanager relabel configurations.
|
||
relabel_configs:
|
||
[ - <relabel_config> ... ]
|
||
```
|
||
|
||
### `<tracing_config>`
|
||
|
||
`tracing_config` configures exporting traces from Prometheus to a tracing backend via the OTLP protocol. Tracing is currently an **experimental** feature and could change in the future.
|
||
|
||
```yaml
|
||
# Client used to export the traces. Options are 'http' or 'grpc'.
|
||
[ client_type: <string> | default = grpc ]
|
||
|
||
# Endpoint to send the traces to. Should be provided in format <host>:<port>.
|
||
[ endpoint: <string> ]
|
||
|
||
# Sets the probability a given trace will be sampled. Must be a float from 0 through 1.
|
||
[ sampling_fraction: <float> | default = 0 ]
|
||
|
||
# If disabled, the client will use a secure connection.
|
||
[ insecure: <boolean> | default = false ]
|
||
|
||
# Key-value pairs to be used as headers associated with gRPC or HTTP requests.
|
||
headers:
|
||
[ <string>: <string> ... ]
|
||
|
||
# Compression key for supported compression types. Supported compression: gzip.
|
||
[ compression: <string> ]
|
||
|
||
# Maximum time the exporter will wait for each batch export.
|
||
[ timeout: <duration> | default = 10s ]
|
||
|
||
# TLS configuration.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
```
|
||
|
||
### `<remote_write>`
|
||
|
||
`write_relabel_configs` is relabeling applied to samples before sending them
|
||
to the remote endpoint. Write relabeling is applied after external labels. This
|
||
could be used to limit which samples are sent.
|
||
|
||
There is a [small demo](/documentation/examples/remote_storage) of how to use
|
||
this functionality.
|
||
|
||
```yaml
|
||
# The URL of the endpoint to send samples to.
|
||
url: <string>
|
||
|
||
# Timeout for requests to the remote write endpoint.
|
||
[ remote_timeout: <duration> | default = 30s ]
|
||
|
||
# Custom HTTP headers to be sent along with each remote write request.
|
||
# Be aware that headers that are set by Prometheus itself can't be overwritten.
|
||
headers:
|
||
[ <string>: <string> ... ]
|
||
|
||
# List of remote write relabel configurations.
|
||
write_relabel_configs:
|
||
[ - <relabel_config> ... ]
|
||
|
||
# Name of the remote write config, which if specified must be unique among remote write configs.
|
||
# The name will be used in metrics and logging in place of a generated value to help users distinguish between
|
||
# remote write configs.
|
||
[ name: <string> ]
|
||
|
||
# Enables sending of exemplars over remote write. Note that exemplar storage itself must be enabled for exemplars to be scraped in the first place.
|
||
[ send_exemplars: <boolean> | default = false ]
|
||
|
||
# Sets the `Authorization` header on every remote write request with the
|
||
# configured username and password.
|
||
# password and password_file are mutually exclusive.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optionally configures AWS's Signature Verification 4 signing process to
|
||
# sign requests. Cannot be set at the same time as basic_auth, authorization, or oauth2.
|
||
# To use the default credentials from the AWS SDK, use `sigv4: {}`.
|
||
sigv4:
|
||
# The AWS region. If blank, the region from the default credentials chain
|
||
# is used.
|
||
[ region: <string> ]
|
||
|
||
# The AWS API keys. If blank, the environment variables `AWS_ACCESS_KEY_ID`
|
||
# and `AWS_SECRET_ACCESS_KEY` are used.
|
||
[ access_key: <string> ]
|
||
[ secret_key: <secret> ]
|
||
|
||
# Named AWS profile used to authenticate.
|
||
[ profile: <string> ]
|
||
|
||
# AWS Role ARN, an alternative to using AWS API keys.
|
||
[ role_arn: <string> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth, authorization, or sigv4.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configures the remote write request's TLS settings.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# Configures the queue used to write to remote storage.
|
||
queue_config:
|
||
# Number of samples to buffer per shard before we block reading of more
|
||
# samples from the WAL. It is recommended to have enough capacity in each
|
||
# shard to buffer several requests to keep throughput up while processing
|
||
# occasional slow remote requests.
|
||
[ capacity: <int> | default = 2500 ]
|
||
# Maximum number of shards, i.e. amount of concurrency.
|
||
[ max_shards: <int> | default = 200 ]
|
||
# Minimum number of shards, i.e. amount of concurrency.
|
||
[ min_shards: <int> | default = 1 ]
|
||
# Maximum number of samples per send.
|
||
[ max_samples_per_send: <int> | default = 500]
|
||
# Maximum time a sample will wait in buffer.
|
||
[ batch_send_deadline: <duration> | default = 5s ]
|
||
# Initial retry delay. Gets doubled for every retry.
|
||
[ min_backoff: <duration> | default = 30ms ]
|
||
# Maximum retry delay.
|
||
[ max_backoff: <duration> | default = 5s ]
|
||
# Retry upon receiving a 429 status code from the remote-write storage.
|
||
# This is experimental and might change in the future.
|
||
[ retry_on_http_429: <boolean> | default = false ]
|
||
|
||
# Configures the sending of series metadata to remote storage.
|
||
# Metadata configuration is subject to change at any point
|
||
# or be removed in future releases.
|
||
metadata_config:
|
||
# Whether metric metadata is sent to remote storage or not.
|
||
[ send: <boolean> | default = true ]
|
||
# How frequently metric metadata is sent to remote storage.
|
||
[ send_interval: <duration> | default = 1m ]
|
||
# Maximum number of samples per send.
|
||
[ max_samples_per_send: <int> | default = 500]
|
||
```
|
||
|
||
There is a list of
|
||
[integrations](https://prometheus.io/docs/operating/integrations/#remote-endpoints-and-storage)
|
||
with this feature.
|
||
|
||
### `<remote_read>`
|
||
|
||
```yaml
|
||
# The URL of the endpoint to query from.
|
||
url: <string>
|
||
|
||
# Name of the remote read config, which if specified must be unique among remote read configs.
|
||
# The name will be used in metrics and logging in place of a generated value to help users distinguish between
|
||
# remote read configs.
|
||
[ name: <string> ]
|
||
|
||
# An optional list of equality matchers which have to be
|
||
# present in a selector to query the remote read endpoint.
|
||
required_matchers:
|
||
[ <labelname>: <labelvalue> ... ]
|
||
|
||
# Timeout for requests to the remote read endpoint.
|
||
[ remote_timeout: <duration> | default = 1m ]
|
||
|
||
# Custom HTTP headers to be sent along with each remote read request.
|
||
# Be aware that headers that are set by Prometheus itself can't be overwritten.
|
||
headers:
|
||
[ <string>: <string> ... ]
|
||
|
||
# Whether reads should be made for queries for time ranges that
|
||
# the local storage should have complete data for.
|
||
[ read_recent: <boolean> | default = false ]
|
||
|
||
# Sets the `Authorization` header on every remote read request with the
|
||
# configured username and password.
|
||
# password and password_file are mutually exclusive.
|
||
basic_auth:
|
||
[ username: <string> ]
|
||
[ password: <secret> ]
|
||
[ password_file: <string> ]
|
||
|
||
# Optional `Authorization` header configuration.
|
||
authorization:
|
||
# Sets the authentication type.
|
||
[ type: <string> | default: Bearer ]
|
||
# Sets the credentials. It is mutually exclusive with
|
||
# `credentials_file`.
|
||
[ credentials: <secret> ]
|
||
# Sets the credentials to the credentials read from the configured file.
|
||
# It is mutually exclusive with `credentials`.
|
||
[ credentials_file: <filename> ]
|
||
|
||
# Optional OAuth 2.0 configuration.
|
||
# Cannot be used at the same time as basic_auth or authorization.
|
||
oauth2:
|
||
[ <oauth2> ]
|
||
|
||
# Configures the remote read request's TLS settings.
|
||
tls_config:
|
||
[ <tls_config> ]
|
||
|
||
# Optional proxy URL.
|
||
[ proxy_url: <string> ]
|
||
|
||
# Configure whether HTTP requests follow HTTP 3xx redirects.
|
||
[ follow_redirects: <boolean> | default = true ]
|
||
|
||
# Whether to enable HTTP2.
|
||
[ enable_http2: <bool> | default: true ]
|
||
|
||
# Whether to use the external labels as selectors for the remote read endpoint.
|
||
[ filter_external_labels: <boolean> | default = true ]
|
||
```
|
||
|
||
There is a list of
|
||
[integrations](https://prometheus.io/docs/operating/integrations/#remote-endpoints-and-storage)
|
||
with this feature.
|
||
|
||
### `<exemplars>`
|
||
|
||
Note that exemplar storage is still considered experimental and must be enabled via `--enable-feature=exemplar-storage`.
|
||
|
||
```yaml
|
||
# Configures the maximum size of the circular buffer used to store exemplars for all series. Resizable during runtime.
|
||
[ max_exemplars: <int> | default = 100000 ]
|
||
```
|