Azure Monitor managed service for Prometheus
Azure Monitor managed service for Prometheus is a component of Azure Monitor Metrics, providing more flexibility in the types of metric data that you can collect and analyze with Azure Monitor. Prometheus metrics share some features with platform and custom metrics, but use some different features to better support open source tools such as PromQL and Grafana.
Azure Monitor managed service for Prometheus allows you to collect and analyze metrics at scale using a Prometheus-compatible monitoring solution, based on the Prometheus project from the Cloud Native Computing Foundation. This fully managed service allows you to use the Prometheus query language (PromQL) to analyze and alert on the performance of monitored infrastructure and workloads without having to operate the underlying infrastructure.
Important
Azure Monitor managed service for Prometheus is intended for storing information about service health of customer machines and applications. It is not intended for storing any data classified as Personal Identifiable Information (PII) or End User Identifiable Information (EUII). We strongly recommend that you do not send any sensitive information (usernames, credit card numbers etc.) into Azure Monitor managed service for Prometheus fields like metric names, label names, or label values.
Data sources
Azure Monitor managed service for Prometheus can currently collect data from any of the following data sources:
- Azure Kubernetes service (AKS)
- Any Kubernetes cluster running self-managed Prometheus using remote-write.
- Azure Arc-enabled Kubernetes
Enable
The only requirement to enable Azure Monitor managed service for Prometheus is to create an Azure Monitor workspace, which is where Prometheus metrics are stored. Once this workspace is created, you can onboard services that collect Prometheus metrics.
- To collect Prometheus metrics from your AKS cluster without using Container insights, see Collect Prometheus metrics from AKS cluster.
- To add collection of Prometheus metrics to your cluster using Container insights, see Collect Prometheus metrics with Container insights.
- To configure remote-write to collect data from your self-managed Prometheus server, see Azure Monitor managed service for Prometheus remote write - managed identity.
- To collect Prometheus metrics from your Azure Arc-enabled Kubernetes cluster without using Container insights, see Collect Prometheus metrics from Azure Arc-enabled Kubernetes cluster
Grafana integration
The primary method for visualizing Prometheus metrics is Azure Managed Grafana. Connect your Azure Monitor workspace to a Grafana workspace so that it can be used as a data source in a Grafana dashboard. You then have access to multiple prebuilt dashboards that use Prometheus metrics and the ability to create any number of custom dashboards.
Rules and alerts
Azure Monitor managed service for Prometheus supports recording rules and alert rules using PromQL queries. Metrics recorded by recording rules are stored back in the Azure Monitor workspace and can be queried by dashboard or by other rules. Alert rules and recording rules can be created and managed using Azure Managed Prometheus rule groups. For your AKS cluster, a set of predefined Prometheus alert rules and recording rules is provided to allow easy quick start.
Alerts fired by alert rules can trigger actions or notifications, as defined in the action groups configured for the alert rule. You can also view fired and resolved Prometheus alerts in the Azure portal along with other alert types.
Service limits & quotas
See Azure Monitor service limits for service limits & quotas for Azure Monitor Managed service for Prometheus.
Limitations/Known issues - Azure Monitor managed Service for Prometheus
- Scraping and storing metrics at frequencies less than 1 second isn't supported.
- Metrics with the same label names but different cases are rejected during ingestion (ex;-
diskSize(cluster="eastus", node="node1", filesystem="usr_mnt", FileSystem="usr_opt")
is invalid due tofilesystem
andFileSystem
labels, and are rejected). - Microsoft Azure operated by 21Vianet cloud and Air gapped clouds aren't supported for Azure Monitor managed service for Prometheus.
- To monitor Windows nodes & pods in your cluster(s), follow steps outlined here.
- Azure Managed Grafana isn't currently available in the Azure US Government cloud.
- Usage metrics (metrics under
Metrics
menu for the Azure Monitor workspace) - Ingestion quota limits and current usage for any Azure monitor Workspace aren't available yet in US Government cloud. - During node updates, you might experience gaps lasting 1 to 2 minutes in some metric collections from our cluster level collector. This gap is due to a regular action from Azure Kubernetes Service to update the nodes in your cluster. This behavior is expected and occurs due to the node it runs on being updated. None of our recommended alert rules are affected by this behavior.
Prometheus references
Following are links to Prometheus documentation.
Frequently asked questions
This section provides answers to common questions.
How do I retrieve Prometheus metrics?
All data is retrieved from an Azure Monitor workspace by using queries that are written in Prometheus Query Language (PromQL). You can write your own queries, use queries from the open source community, and use Grafana dashboards that include PromQL queries. See the Prometheus project.
Can I view my Prometheus metrics in Azure Monitor metrics explorer?
Metrics explorer in Azure Monitor doesn't currently support visualizing Prometheus metric data. Consider using Azure Managed Grafana to visualize your Prometheus metrics.
When I use managed service for Prometheus, can I store data for more than one cluster in an Azure Monitor workspace?
Yes. Managed service for Prometheus is intended to enable scenarios where you can store data from several Azure Kubernetes Service clusters in a single Azure Monitor workspace. See Azure Monitor workspace overview.
What types of resources can send Prometheus metrics to managed service for Prometheus?
Our agent can be used on Azure Kubernetes Service clusters and Azure Arc-enabled Kubernetes clusters. It's installed as a managed add-on for AKS clusters and an extension for Azure Arc-enabled Kubernetes clusters and you can configure it to collect the data you want. You can also configure remote write on Kubernetes clusters running in Azure, another cloud, or on-premises by following our instructions for enabling remote write.
If you use the Azure portal to enable Prometheus metrics collection and install the AKS add-on or Azure Arc-enabled Kubernetes extension from the Insights page of your cluster, it enables logs collection into Log Analytics and Prometheus metrics collection into managed service for Prometheus. For more information, see Data sources.
Next steps
Feedback
Submit and view feedback for