alertmanager/docs/alerts_api.md
George Robinson b15eed57d3 Fix extra space at the end of here
Signed-off-by: George Robinson <george.robinson@grafana.com>
2025-03-11 11:58:56 +00:00

2.7 KiB

title sort_rank nav_icon
Alerts API 6 sliders

Important: Prometheus takes care of sending alerts to the Alertmanager. It is recommended to configure alerting rules in Prometheus based on time series data instead of sending alerts to the Alerts API, as Prometheus supports a number of special cases to make sure alerts are delivered even if Alertmanager crashes or restarts.

Alerts API

You send alerts to Alertmanager via APIv2. The APIv2 is specified as an OpenAPI specification that can be found here.

APIv1 was deprecated in Alertmanager version 0.16.0 and removed in Alertmanager version 0.27.0.

To send alerts to APIv2 make a POST request to api/v2/alerts. You must set the Content-Type header to application/json, and send JSON data containing an array of alerts.

Here is an example:

[
  {
    "labels": {
      "alertname": "<required_value>",
      "<name>": "<value>",
      ...
    },
    "annotations": {
      "<name>": "<value>",
    },
    "startsAt": "<RFC3339>",
    "endsAt": "<RFC3339>",
    "generatorURL": "<value>"
  },
  ...
]

All alerts have labels, annotations, an optional startsAt timestamp and an optional endsAt timestamp. All timestamps are expected in the RFC3339 format.

Labels are used to deduplicate identical instances of the same alert, while annotations are used to include other information about the alert, such as a summary, description or a URL to a runbook.

The startsAt timestamp is the time the alert fired. If omitted, Alertmanager sets startsAt to the current time.

The endsAt timestamp is the time the alert should be resolved. If omitted, Alertmanager sets endsAt to the current time + resolve_timeout.

The generatorURL is a unique URL which links to the source of the alert. For example, it might link to the firing rule in Prometheus.

Expectations from clients

Clients are expected to re-send firing alerts to the Alertmanager at regular intervals until the alert is resolved.

The exact interval depends on a number of variables such as the endsAt timestamp, or if omitted the value of resolve_timeout. If the endsAt timestamp is omitted, the Alertmanager will update the existing endsAt timestamp for the alert to the current time + resolve_timeout.

Firing alerts are resolved once their endsAt timestamp has elapsed.

To ensure resolved notifications are sent for resolved alerts, clients are also expected to re-send resolved alerts to the Alertmanager for up to 5 minutes after the alert has resolved. As the Alertmanager is stateless, this ensures that a resolved notification is sent even if the Alertmanager crashes or is restarted.