From 8a42cbc9b53abd78ad41cc65e8d7ec9cf02f18d1 Mon Sep 17 00:00:00 2001 From: Julius Volz Date: Wed, 4 Jan 2023 20:05:14 +0100 Subject: [PATCH] Multiple improvements to Alertmanager configuration docs * The current page outline was an unstructured and unsorted mess, so I tried to organize the different configuration file fields into categories. * I also sorted receivers alphabetically. * Corrected the Telegram receiver's "bot_token" to be a "secret", not "string". * Other minor improvements and wording additions to the sections. Signed-off-by: Julius Volz --- docs/configuration.md | 358 +++++++++++++++++++++++------------------- 1 file changed, 194 insertions(+), 164 deletions(-) diff --git a/docs/configuration.md b/docs/configuration.md index 711972e73e..d9da5aec45 100644 --- a/docs/configuration.md +++ b/docs/configuration.md @@ -20,9 +20,9 @@ To view all available command-line flags, run `alertmanager -h`. Alertmanager can reload its configuration at runtime. If the new configuration is not well-formed, the changes will not be applied and an error is logged. A configuration reload is triggered by sending a `SIGHUP` to the process or -sending a HTTP POST request to the `/-/reload` endpoint. +sending an HTTP POST request to the `/-/reload` endpoint. -## Configuration file +## Configuration file introduction To specify which configuration file to load, use the `--config.file` flag. @@ -47,15 +47,18 @@ Generic placeholders are defined as follows: * ``: a string which is template-expanded before usage * ``: a string which is template-expanded before usage that is a secret * ``: an integer value +* ``: any valid [RE2 regular expression](https://github.com/google/re2/wiki/Syntax) (The regex is anchored on both ends. To un-anchor the regex, use `.*.*`.) The other placeholders are specified separately. A provided [valid example file](https://github.com/prometheus/alertmanager/blob/main/doc/examples/simple.yml) shows usage in context. +## File layout and global settings + The global configuration specifies parameters that are valid in all other configuration contexts. They also serve as defaults for other configuration -sections. +sections. The other top-level sections are documented below on this page. ```yaml global: @@ -130,7 +133,11 @@ time_intervals: [ - ... ] ``` -## `` +## Route-related settings + +Routing-related settings allow configuring how alerts are routed, aggregated, throttled, and muted based on time. + +### `` A route block defines a node in a routing tree and its children. Its optional configuration parameters are inherited from its parent node if not set. @@ -213,7 +220,7 @@ routes: [ - ... ] ``` -### Example +#### Example ```yaml # The root route with all parameters, which are inherited by the child @@ -262,7 +269,7 @@ route: - holidays ``` -## `` +### `` A `time_interval` specifies a named interval of time that may be referenced in the routing tree to mute/activate particular routes for particular times of the day. @@ -270,10 +277,11 @@ in the routing tree to mute/activate particular routes for particular times of t ```yaml name: time_intervals: - [ - ... ] + [ - ... ] ``` -## `` -A `time_interval` contains the actual definition for an interval of time. The syntax +#### `` + +A `time_interval_spec` contains the actual definition for an interval of time. The syntax supports the following fields: ```yaml @@ -343,7 +351,13 @@ interval is taken to be in UTC time.**Note:** On Windows, only `Local` or `UTC` supported unless you provide a custom time zone database using the `ZONEINFO` environment variable. -## `` +## Inhibition-related settings + +Inhibition allows muting a set of alerts based on the presence of another set of +alerts. This allows establishing dependencies between systems or services such that +only the most relevant of a set of interconnected alerts are sent out during an outage. + +### `` An inhibition rule mutes an alert (target) matching a set of matchers when an alert (source) exists that matches another set of matchers. @@ -394,9 +408,118 @@ source_matchers: ``` -## `` +## Label matchers + +Label matchers are used both in routes and inhibition rules to match certain alerts. + +### `` + +A matcher is a string with a syntax inspired by PromQL and OpenMetrics. The syntax of a matcher consists of three tokens: + +- A valid Prometheus label name. + +- One of `=`, `!=`, `=~`, or `!~`. `=` means equals, `!=` means that the strings are not equal, `=~` is used for equality of regex expressions and `!~` is used for un-equality of regex expressions. They have the same meaning as known from PromQL selectors. + +- A UTF-8 string, which may be enclosed in double quotes. Before or after each token, there may be any amount of whitespace. + +The 3rd token may be the empty string. Within the 3rd token, OpenMetrics escaping rules apply: `\"` for a double-quote, `\n` for a line feed, `\\` for a literal backslash. Unescaped `"` must not occur inside the 3rd token (only as the 1st or last character). However, literal line feed characters are tolerated, as are single `\` characters not followed by `\`, `n`, or `"`. They act as a literal backslash in that case. + +Matchers are ANDed together, meaning that all matchers must evaluate to "true" when tested against the labels on a given alert. For example, an alert with these labels: + +```json +{"alertname":"Watchdog","severity":"none"} +``` + +would NOT match this list of matchers: + +```yaml +matchers: + - alertname = Watchdog + - severity =~ "warning|critical" +``` + +In the configuration, multiple matchers are combined in a YAML list. However, it is also possible to combine multiple matchers within a single YAML string, again using syntax inspired by PromQL. In such a string, a leading `{` and/or a trailing `}` is optional and will be trimmed before further parsing. Individual matchers are separated by commas outside of quoted parts of the string. Those commas may be surrounded by whitespace. Parts of the string inside unescaped double quotes `"…"` are considered quoted (and commas don't act as separators there). If double quotes are escaped with a single backslash `\`, they are ignored for the purpose of identifying quoted parts of the input string. If the input string, after trimming the optional trailing `}`, ends with a comma, followed by optional whitespace, this comma and whitespace will be trimmed. + +Here are some examples of valid string matchers: + +1. Shown below are two equality matchers combined in a long form YAML list. + + ```yaml + matchers: + - foo = bar + - dings !=bums + ``` + +2. Similar to example 1, shown below are two equality matchers combined in a short form YAML list. + + ```yaml + matchers: [ foo = bar, dings != bums ] + ``` + + As shown below, in the short-form, it's generally better to quote the list elements to avoid problems with special characters like commas: + + ```yaml + matchers: [ "foo = bar,baz", "dings != bums" ] + ``` + +3. You can also put both matchers into one PromQL-like string. Single quotes for the whole string work best here. + + ```yaml + matchers: [ '{foo="bar",dings!="bums"}' ] + ``` + +4. To avoid any confusion about YAML string quoting and escaping, you can use YAML block quoting and then only worry about the OpenMetrics escaping inside the block. A complex example with a regular expression and different quotes inside the label value is shown below: + + ```yaml + matchers: + - | + {quote=~"She said: \"Hi, all!( How're you…)?\""} + ``` + +## General receiver-related settings + +These receiver settings allow configuring notification destinations (receivers) and HTTP client options for HTTP-based receivers. + +### `` + +Receiver is a named configuration of one or more notification integrations. + +Note: As part of lifting the past moratorium on new receivers it was agreed that, in addition to the existing requirements, new notification integrations will be required to have a committed maintainer with push access. + +```yaml +# The unique name of the receiver. +name: + +# Configurations for several notification integrations. +discord_configs: + [ - , ... ] +email_configs: + [ - , ... ] +opsgenie_configs: + [ - , ... ] +pagerduty_configs: + [ - , ... ] +pushover_configs: + [ - , ... ] +slack_configs: + [ - , ... ] +sns_configs: + [ - , ... ] +telegram_configs: + [ - , ... ] +victorops_configs: + [ - , ... ] +webex_configs: + [ - , ... ] +webhook_configs: + [ - , ... ] +wechat_configs: + [ - , ... ] +``` + +### `` -A `http_config` allows configuring the HTTP client that the receiver uses to +An `http_config` allows configuring the HTTP client that the receiver uses to communicate with HTTP-based API services. ```yaml @@ -439,7 +562,7 @@ tls_config: [ ] ``` -### `oauth2` +#### `` OAuth 2.0 authentication using the client credentials grant type. Alertmanager fetches an access token from the specified endpoint with @@ -472,7 +595,7 @@ tls_config: [ proxy_url: ] ``` -## `` +#### `` A `tls_config` allows configuring TLS connections. @@ -503,44 +626,32 @@ A `tls_config` allows configuring TLS connections. [ max_version: ] ``` -## `` +## Receiver integration settings -Receiver is a named configuration of one or more notification integrations. +These settings allow configuring specific receiver integrations. -Note: As part of lifting the past moratorium on new receivers it was agreed that, in addition to the existing requirements, new notification integrations will be required to have a committed maintainer with push access. +### `` + +Discord notifications are sent via the [Discord webhook API](https://discord.com/developers/docs/resources/webhook). See Discord's ["Intro to Webhooks" article](https://support.discord.com/hc/en-us/articles/228383668-Intro-to-Webhooks) to learn how to configure a webhook integration for a channel. ```yaml -# The unique name of the receiver. -name: +# Whether to notify about resolved alerts. +[ send_resolved: | default = true ] -# Configurations for several notification integrations. -email_configs: - [ - , ... ] -opsgenie_configs: - [ - , ... ] -pagerduty_configs: - [ - , ... ] -pushover_configs: - [ - , ... ] -slack_configs: - [ - , ... ] -sns_configs: - [ - , ... ] -victorops_configs: - [ - , ... ] -webhook_configs: - [ - , ... ] -wechat_configs: - [ - , ... ] -telegram_configs: - [ - , ... ] -webex_configs: - [ - , ... ] -discord_configs: - [ - , ... ] +# The Discord webhook URL. +webhook_url: + +# Message title template. +[ title: | default = '{{ template "discord.default.title" . }}' ] + +# Message body template. +[ message: | default = '{{ template "discord.default.message" . }}' ] + +# The HTTP client's configuration. +[ http_config: | default = global.http_config ] ``` -## `` +### `` ```yaml # Whether to notify about resolved alerts. @@ -584,7 +695,7 @@ tls_config: [ headers: { : , ... } ] ``` -## `` +### `` OpsGenie notifications are sent via the [OpsGenie API](https://docs.opsgenie.com/docs/alert-api). @@ -642,7 +753,7 @@ responders: [ http_config: | default = global.http_config ] ``` -### `` +#### `` ```yaml # Exactly one of these fields should be defined. @@ -654,7 +765,7 @@ responders: type: ``` -## `` +### `` PagerDuty notifications are sent via the [PagerDuty API](https://developer.pagerduty.com/documentation/integration/events). PagerDuty provides [documentation](https://www.pagerduty.com/docs/guides/prometheus-integration-guide/) on how to integrate. There are important differences with Alertmanager's v0.11 and greater support of PagerDuty's Events API v2. @@ -724,7 +835,7 @@ links: [ http_config: | default = global.http_config ] ``` -### `` +#### `` The fields are documented in the [PagerDuty API documentation](https://developer.pagerduty.com/docs/events-api-v2/trigger-events/#the-images-property). @@ -734,7 +845,7 @@ source: alt: ``` -### `` +#### `` The fields are documented in the [PagerDuty API documentation](https://developer.pagerduty.com/docs/events-api-v2/trigger-events/#the-links-property). @@ -743,7 +854,7 @@ href: text: ``` -## `` +### `` Pushover notifications are sent via the [Pushover API](https://pushover.net/api). @@ -783,7 +894,7 @@ token: [ http_config: | default = global.http_config ] ``` -## `` +### `` Slack notifications are sent via [Slack webhooks](https://api.slack.com/messaging/webhooks). The notification contains @@ -828,7 +939,7 @@ fields: [ http_config: | default = global.http_config ] ``` -### `` +#### `` The fields are documented in the Slack API documentation for [message attachments](https://api.slack.com/messaging/composing/layouts#attachments) and [interactive messages](https://api.slack.com/legacy/interactive-message-field-guide#action_fields). @@ -844,7 +955,7 @@ type: [ style: | default = '' ] ``` -#### `` +##### `` The fields are documented in the [Slack API documentation](https://api.slack.com/legacy/interactive-message-field-guide#confirmation_fields). @@ -855,7 +966,7 @@ text: [ title: | default '' ] ``` -### `` +#### `` The fields are documented in the [Slack API documentation](https://api.slack.com/messaging/composing/layouts#attachments). @@ -865,7 +976,8 @@ value: [ short: | default = slack_config.short_fields ] ``` -## `` +### `` + ```yaml # Whether to notify about resolved alerts. [ send_resolved: | default = true ] @@ -906,7 +1018,8 @@ attributes: [ http_config: | default = global.http_config ] ``` -### `` +#### `` + ```yaml # The AWS region. If blank, the region from the default credentials chain is used. [ region: ] @@ -923,71 +1036,36 @@ attributes: [ role_arn: ] ``` -## `` - -A matcher is a string with a syntax inspired by PromQL and OpenMetrics. The syntax of a matcher consists of three tokens: - -- A valid Prometheus label name. - -- One of `=`, `!=`, `=~`, or `!~`. `=` means equals, `!=` means that the strings are not equal, `=~` is used for equality of regex expressions and `!~` is used for un-equality of regex expressions. They have the same meaning as known from PromQL selectors. - -- A UTF-8 string, which may be enclosed in double quotes. Before or after each token, there may be any amount of whitespace. - -The 3rd token may be the empty string. Within the 3rd token, OpenMetrics escaping rules apply: `\"` for a double-quote, `\n` for a line feed, `\\` for a literal backslash. Unescaped `"` must not occur inside the 3rd token (only as the 1st or last character). However, literal line feed characters are tolerated, as are single `\` characters not followed by `\`, `n`, or `"`. They act as a literal backslash in that case. - -Matchers are ANDed together, meaning that all matchers must evaluate to "true" when tested against the labels on a given alert. For example, an alert with these labels: - -```json -{"alertname":"Watchdog","severity":"none"} -``` - -would NOT match this list of matchers: +### `` ```yaml -matchers: - - alertname = Watchdog - - severity =~ "warning|critical" -``` - -In the configuration, multiple matchers are combined in a YAML list. However, it is also possible to combine multiple matchers within a single YAML string, again using syntax inspired by PromQL. In such a string, a leading `{` and/or a trailing `}` is optional and will be trimmed before further parsing. Individual matchers are separated by commas outside of quoted parts of the string. Those commas may be surrounded by whitespace. Parts of the string inside unescaped double quotes `"…"` are considered quoted (and commas don't act as separators there). If double quotes are escaped with a single backslash `\`, they are ignored for the purpose of identifying quoted parts of the input string. If the input string, after trimming the optional trailing `}`, ends with a comma, followed by optional whitespace, this comma and whitespace will be trimmed. - -Here are some examples of valid string matchers: - -1. Shown below are two equality matchers combined in a long form YAML list. - - ```yaml - matchers: - - foo = bar - - dings !=bums - ``` - -2. Similar to example 1, shown below are two equality matchers combined in a short form YAML list. +# Whether to notify about resolved alerts. +[ send_resolved: | default = true ] - ```yaml - matchers: [ foo = bar, dings != bums ] - ``` +# The Telegram API URL i.e. https://api.telegram.org. +# If not specified, default API URL will be used. +[ api_url: | default = global.telegram_api_url ] - As shown below, in the short-form, it's generally better to quote the list elements to avoid problems with special characters like commas: +# Telegram bot token. +[ bot_token: ] - ```yaml - matchers: [ "foo = bar,baz", "dings != bums" ] - ``` +# ID of the chat where to send the messages. +[ chat_id: ] -3. You can also put both matchers into one PromQL-like string. Single quotes for the whole string work best here. +# Message template. +[ message: default = '{{ template "telegram.default.message" .}}' ] - ```yaml - matchers: [ '{foo="bar",dings!="bums"}' ] - ``` +# Disable telegram notifications +[ disable_notifications: | default = false ] -4. To avoid any confusion about YAML string quoting and escaping, you can use YAML block quoting and then only worry about the OpenMetrics escaping inside the block. A complex example with a regular expression and different quotes inside the label value is shown below: +# Parse mode for telegram message, supported values are MarkdownV2, Markdown, HTML and empty string for plain text. +[ parse_mode: | default = "HTML" ] - ```yaml - matchers: - - | - {quote=~"She said: \"Hi, all!( How're you…)?\""} - ``` +# The HTTP client's configuration. +[ http_config: | default = global.http_config ] +``` -## `` +### `` VictorOps notifications are sent out via the [VictorOps API](https://help.victorops.com/knowledge-base/rest-endpoint-integration-guide/) @@ -1025,7 +1103,7 @@ routing_key: [ http_config: | default = global.http_config ] ``` -## `` +### `` The webhook receiver allows configuring a generic receiver. @@ -1079,7 +1157,7 @@ There is a list of [integrations](https://prometheus.io/docs/operating/integrations/#alertmanager-webhook-receiver) with this feature. -## `` +### `` WeChat notifications are sent via the [WeChat API](http://admin.wechat.com/wiki/index.php?title=Customer_Service_Messages). @@ -1107,35 +1185,8 @@ API](http://admin.wechat.com/wiki/index.php?title=Customer_Service_Messages). [ to_tag: | default = '{{ template "wechat.default.to_tag" . }}' ] ``` -## `` -```yaml -# Whether to notify about resolved alerts. -[ send_resolved: | default = true ] - -# The Telegram API URL i.e. https://api.telegram.org. -# If not specified, default API URL will be used. -[ api_url: | default = global.telegram_api_url ] - -# Telegram bot token -[ bot_token: ] - -# ID of the chat where to send the messages. -[ chat_id: ] - -# Message template -[ message: default = '{{ template "telegram.default.message" .}}' ] - -# Disable telegram notifications -[ disable_notifications: | default = false ] - -# Parse mode for telegram message, supported values are MarkdownV2, Markdown, HTML and empty string for plain text. -[ parse_mode: | default = "HTML" ] +### `` -# The HTTP client's configuration. -[ http_config: | default = global.http_config ] -``` - -## `` ```yaml # Whether to notify about resolved alerts. [ send_resolved: | default = true ] @@ -1147,30 +1198,9 @@ API](http://admin.wechat.com/wiki/index.php?title=Customer_Service_Messages). # ID of the Webex Teams room where to send the messages. room_id: -# Message template +# Message template. [ message: default = '{{ template "webex.default.message" .}}' ] # The HTTP client's configuration. You must use this configuration to supply the bot token as part of the HTTP `Authorization` header. [ http_config: | default = global.http_config ] ``` - -## `` - -Discord notifications are sent via the [Discord webhook API](https://discord.com/developers/docs/resources/webhook). See Discord's ["Intro to Webhooks" article](https://support.discord.com/hc/en-us/articles/228383668-Intro-to-Webhooks) to learn how to configure a webhook integration for a channel. - -```yaml -# Whether to notify about resolved alerts. -[ send_resolved: | default = true ] - -# The Discord webhook URL. -webhook_url: - -# Message title template. -[ title: | default = '{{ template "discord.default.title" . }}' ] - -# Message body template. -[ message: | default = '{{ template "discord.default.message" . }}' ] - -# The HTTP client's configuration. -[ http_config: | default = global.http_config ] -```