This is documentation for the next version of Grafana documentation. For the latest stable release, go to the latest version.
Import data source-managed rules to Grafana-managed rules
You can convert existing alert rules from data sources such as Mimir, Loki, and Prometheus into Grafana-managed alert rules. This enables you to operate and manage these rules using Grafana Alerting.
This guide explains two methods for importing data source-managed rules:
- Using the Grafana Alerting user interface to import rules from connected data sources or Prometheus rule YAML files. 
- Using command-line tools like - mimirtooland- cortextoolto import rules from YAML files.
Importing rules is a safe operation: the original data source–managed rules remain intact in their original location. During import, the rules are converted into Grafana-managed rules while preserving their configuration and behavior.
Choose the method that best fits your workflow. As a best practice, test and validate your import process before migrating all alert rules.
How it works
When you use any of the import methods, data source–managed rules are copied to another folder as Grafana-managed rules.
The original data source–managed rules remain intact in their original location.
The copied rules are converted to Grafana-managed rules, preserving their behavior by using equivalent Grafana-managed features. The following settings are applied during the conversion:
- Unique UIDs - The newly created rules are assigned unique UIDs. If you don’t want a UID to be auto-generated, you can specify one using the - __grafana_alert_rule_uid__label.
- Query offset - A query offset is applied to each rule. For example, an offset of - 1madjusts the query’s time range to- To: now-1m.- The rule query offset is taken from the - query_offsetvalue in the rule group configuration. If empty, it defaults to the- rule_query_offsetconfiguration setting, which is- 1mby default.
- Missing series evaluations to resolve - The Missing series evaluations to resolve setting is set to - 1to replicate Prometheus’s alert eviction behavior.
- Rule group labels - Labels defined at the rule group level are added as labels to each imported rule within the group. 
- Sequential evaluation - Imported rules are evaluated sequentially within each rule group, mirroring Prometheus behavior. This differs from native Grafana-managed alert rules, where the evaluation order is not enforced. For more details, refer to evaluation strategies. 
- Feature compatibility - The rule group - limitoption and the- queryfunction within alert rule templates are not currently supported in Grafana-managed rules. If the- limitoption is present, the import fails. However, rules with- queryin templates are imported.
Note
Rules with the label
__grafana_originare not included in rule imports. These rules are typically created by apps such as Kubernetes Monitoring, Synthetic Monitoring, and other Grafana plugins.
Import rules with Grafana Alerting
You can use the Grafana Alerting user interface to import rules from the following sources:
- Connected Mimir and Loki data sources with the ruler API enabled
- Prometheus YAML rule files
Imported rules using this method are editable in the user interface. Like regular Grafana-managed rules, you can later export them for provisioning.
Before you begin
To use Grafana Alerting to migrate rules, you need the following RBAC permissions:
- Alerting: - Rules Writer,- Set provisioning status.
- Datasources: - Reader.
- Folders: - Creator.- The Folders permission is optional and only necessary if you want to create new folders for your target namespace. If your account doesn’t have permissions to view a namespace, the tool creates a new one. 
To convert data source-managed alert rules to Grafana managed alerts:
- Go to Alerting > Alert rules. 
- Navigate to the Data source-managed alert rules section and click Import to Grafana-managed rules. 
- Choose the Import source from which you want to import rules: - Select Existing data source-managed rules to import rules from connected Mimir or Loki data sources with the ruler API enabled.
- Select Prometheus YAML file to import rules by uploading a Prometheus YAML rule file.
 
- In the Data source dropdown, select the data source that the imported alert rules will query. 
- (Optional) In Additional settings, select a target folder or designate a new folder to import the rules into. - If you import the rules into an existing folder, don’t choose a folder with existing alert rules, as they could get overwritten. 
- (Optional) Select a Namespace and/or Group to determine which rules are imported. 
- (Optional) Turn on Pause imported alerting rules. - Pausing stops alert rule evaluation and doesn’t create any alert instances for the newly created Grafana-managed alert rules. 
- (Optional) Turn on Pause imported recording rules. - Pausing stops alert rule evaluation behavior for the newly created Grafana-managed alert rules. 
- (Optional) In the Target data source of the Recording rules section, you can select the data source that the imported recording rules will query. By default, it is the data source selected in the Data source dropdown. 
- Click Import. - A preview shows the rules that will be imported. If your target folder contains folders with the same name of the imported folders, a warning displays to inform you. You can explore the warning to see a list of folders that might be overwritten. - Click Yes, import to import the rules. 
Import rules with command-line tools
You can also use command-line tools to import data source-managed rules as Grafana-managed rules: use mimirtool for Mimir and Prometheus rules, and cortextool for Loki rules.
Both tools provide rules commands to import rules groups. For example:
- rules loadcan import rule groups from files.
- rules synccan read rule files and applies only the differences compared to existing Grafana-managed rules. This is useful for automation workflows and pipelines.
By default, rules imported using the API or command-line tools are Provisioned and not editable in the user interface. To make them editable, enable the X-Disable-Provenance header.
Before you begin
You need to have installed mimirtool or cortextool (version 0.11.3 or later).
You need a service account with the following RBAC permissions:
- Alerting: Rules Reader,Rules Writer,Set provisioning status.
- Datasources: Reader.
- Folders: Creator,Reader,Writer.
You need to a service account token with your service account. For more details, refer to service accounts and service account tokens.
mimirtool
To convert and import them into a Grafana instance, you can use the mimirtool rules load command:
MIMIR_ADDRESS=<GRAFANA_BASE_URL>/api/convert/ \
MIMIR_AUTH_TOKEN=<SERVICE_ACCOUNT_TOKEN> \
MIMIR_TENANT_ID=1 \
mimirtool rules load rule_file.yaml \
  --extra-headers "X-Grafana-Alerting-Datasource-UID=<DATASOURCE_UID_QUERY_TARGET>"This command imports Prometheus alert rules defined in rule_file.yaml as Grafana-managed alert rules. It’s important to know that:
- When using the <GRAFANA_BASE_URL>/api/convert/endpoint,mimirtoolinteracts with Grafana—not with a Mimir instance. In this case,MIMIR_TENANT_IDmust always be set to1.
- The X-Grafana-Alerting-Datasource-UIDheader configures the data source that the imported alert rules will query. Use multiple--extra-headersflags to include other optional headers.
Similarly, the rules sync command can import and update Grafana-managed alert rules.
MIMIR_ADDRESS=<GRAFANA_BASE_URL>/api/convert/ \
MIMIR_AUTH_TOKEN=<SERVICE_ACCOUNT_TOKEN> \
MIMIR_TENANT_ID=1 \
mimirtool rules sync rule_file.yaml \
  --extra-headers "X-Grafana-Alerting-Datasource-UID=<DATASOURCE_UID_QUERY_TARGET>" \
  --concurrency 1The --concurrency flag must be set to 1, as the default value of 8 may cause API errors.
This sync command reads rules from the file, compares them with the existing Grafana-managed rules in the instance, and applies only the differences—creating, updating, or deleting rules as needed.
## Sync Summary: 0 Groups Created, 1 Groups Updated, 0 Groups DeletedFor more information other Mimirtool commands and options, see the Mimirtool documentation and the Mimir HTTP Rule API documentation.
cortextool
For Loki alert rules, use cortextool (version 0.11.3 or later) with the --backend=loki flag. For example:
CORTEX_ADDRESS=<GRAFANA_BASE_URL>/api/convert/ \
CORTEX_AUTH_TOKEN=<SERVICE_ACCOUNT_TOKEN> \
CORTEX_TENANT_ID=1 \
cortextool rules load loki_rules.yaml \
  --extra-headers "X-Grafana-Alerting-Datasource-UID=<LOKI_DATASOURCE_UID_QUERY_TARGET>" \
  --backend=lokiOptional Headers
Additional configuration headers for more granular import control include the following:
X-Disable-Provenance
When this header is set to true:
- The imported rules are not marked as provisioned.
- They can then be edited in the Grafana UI.
- They are excluded from the GETandDELETEoperations on the/api/convertendpoints.
Do not enable this header when using the rules sync command, as it relies on the GET and DELETE operations to detect and update existing rules.
X-Grafana-Alerting-Alert-Rules-Paused
Set to true to import alert rules in paused state.
X-Grafana-Alerting-Recording-Rules-Paused
Set to true to import recording rules in paused state.
X-Grafana-Alerting-Datasource-UID
The UID of the data source to use for alert rule queries.
X-Grafana-Alerting-Target-Datasource-UID
The UID of the target data source for recording rules. If not specified, the value from X-Grafana-Alerting-Datasource-UID is used.
X-Grafana-Alerting-Folder-UID
Enter the UID of the target destination folder for imported rules.
X-Grafana-Alerting-Notification-Settings
JSON-encoded AlertRuleNotificationSettings object that allows setting the contact point for the alert rules.
AlertRuleNotificationSettings object
When you set X-Grafana-Alerting-Notification-Settings, the header value must be a JSON-encoded object with the following keys:
| Field | Type | Required | Example | Description | 
|---|---|---|---|---|
| receiver | string | Yes | "grafana-default-email" | Name of the contact point (receiver) to which alerts are routed. Must exist in Grafana before import. | 
| group_by | []string | No | ["alertname","grafana_folder","cluster"] | Label set used by Alertmanager to aggregate alerts into a single notification. | 
| group_wait | duration | No | "30s" | How long Alertmanager waits before sending the first notification for a new group. | 
| group_interval | duration | No | "5m" | Time to wait before adding new alerts to an existing group’s next notification. | 
| repeat_interval | duration | No | "4h" | Minimum time before a previously-sent notification is repeated. Must not be less than group_interval. | 
| mute_time_intervals | []string | No | ["maintenance"] | One or more mute time interval names that silence alerts during those windows. | 
| active_time_intervals | []string | No | ["maintenance"] | List of active time interval names. Alerts are suppressed unless the current time matches one of them. | 
Compatible endpoints
The API endpoints listed in this section are supported in Grafana and are used by mimirtool and cortextool, as shown earlier. These endpoints are compatible with Mimir HTTP API.
In these endpoints, a “namespace” corresponds to a folder title in Grafana.
The POST endpoints can be used to import data source–managed alert rules. They accept requests in both YAML and JSON. If no media type is specified, YAML is assumed.
| Endpoint | Method | Summary | Mimir equivalent | 
|---|---|---|---|
| POST | /convert/prometheus/config/v1/rules | Create or update multiple rule groups across multiple namespaces. Requires X-Grafana-Alerting-Datasource-UID. | None | 
| POST | /convert/prometheus/config/v1/rules/:namespaceTitle | Create or update a single rule group in a namespace. Requires X-Grafana-Alerting-Datasource-UID. | Set rule group | 
The GET and DELETE endpoints work only with provisioned and imported alert rules. All GET endpoints support both JSON and YAML response formats based on the Accept header: use application/json for JSON responses, or application/yaml for YAML responses. YAML is the default format when no Accept header is specified.
| Endpoint | Method | Summary | Mimir equivalent | 
|---|---|---|---|
| GET | /convert/prometheus/config/v1/rules | Get all imported rule groups across all namespaces. | List rule groups | 
| GET | /convert/prometheus/config/v1/rules/:namespaceTitle | Get imported rule groups in a specific namespace. | Get rule groups by namespace | 
| GET | /convert/prometheus/config/v1/rules/:namespaceTitle/:group | Get imported rule group in a specific namespace. | Get rule group | 
| DELETE | /convert/prometheus/config/v1/rules/:namespaceTitle | Delete all imported alert rules in a namespace. | Delete namespace | 
| DELETE | /convert/prometheus/config/v1/rules/:namespaceTitle/:group | Delete a specific imported rule group. | Delete rule group | 
Create or update multiple rule groups
POST /convert/prometheus/config/v1/rulesCreates or updates multiple rule groups across multiple namespaces. This endpoint expects a request with a map of namespace titles to arrays of rule groups, and returns 202 on success.
This endpoint has no Mimir equivalent and is Grafana-specific for bulk operations.
Example request body
namespace1:
  - name: MyGroupName1
    rules:
      - alert: MyAlertName1
        expr: up == 0
        labels:
          severity: warning
namespace2:
  - name: MyGroupName2
    rules:
      - alert: MyAlertName2
        expr: rate(http_requests_total[5m]) > 0.1
        labels:
          severity: critical






