diff --git a/docs/sources/operations/meta-monitoring/_index.md b/docs/sources/operations/meta-monitoring/_index.md new file mode 100644 index 0000000000000..eceeab0e648f3 --- /dev/null +++ b/docs/sources/operations/meta-monitoring/_index.md @@ -0,0 +1,103 @@ +--- +title: Monitor Loki +description: Describes the various options for monitoring your Loki environment, and the metrics available. +aliases: + - ../operations/observability +--- + +# Monitor Loki + +As part of your Loki implementation, you will also want to monitor your Loki cluster. + +As a best practice, you should collect data about Loki in a separate instance of Loki, for example, send your Loki data to a [Grafana Cloud account](https://grafana.com/products/cloud/). This will let you troubleshoot a broken Loki cluster from a working one. + +Loki exposes the following observability data about itself: + +- **Metrics**: Loki provides a `/metrics` endpoint that exports information about Loki in Prometheus format. These metrics provide aggregated metrics of the health of your Loki cluster, allowing you to observe query response times, etc etc. +- **Logs**: Loki emits a detailed log line `metrics.go` for every query, which shows query duration, number of lines returned, query throughput, the specific LogQL that was executed, chunks searched, and much more. You can use these log lines to improve and optimize your query performance. + +You can also scrape Loki's logs and metrics and push them to separate instances of Loki and Mimir to provide information about the health of your Loki system (a process known as "meta-monitoring"). + +The Loki [mixin](https://github.com/grafana/loki/blob/main/production/loki-mixin) is an opinionated set of dashboards, alerts and recording rules to monitor your Loki cluster. The mixin provides a comprehensive package for monitoring Loki in production. You can install the mixin into a Grafana instance. + +- To install meta-monitoring using the Loki Helm Chart and Grafana Cloud, follow [these directions](https://grafana.com/docs/loki//setup/install/helm/monitor-and-alert/with-grafana-cloud/). + +- To install meta-monitoring using the Loki Helm Chart and a local Loki stack, follow [these directions](https://grafana.com/docs/loki//setup/install/helm/monitor-and-alert/with-local-monitoring/). + +- To install the Loki mixin, follow [these directions]({{< relref "./mixins" >}}). + +You should also plan separately for infrastructure-level monitoring, to monitor the capacity or throughput of your storage provider, for example, or your networking layer. + +- [MinIO](https://min.io/docs/minio/linux/operations/monitoring/collect-minio-metrics-using-prometheus.html) +- [Kubernetes](https://grafana.com/docs/grafana-cloud/monitor-infrastructure/kubernetes-monitoring/) + +## Loki Metrics + +As Loki is a [distributed system](https://grafana.com/docs/loki//get-started/components/), each component exports its own metrics. The `/metrics` endpoint exposes hundreds of different metrics. You can find a sampling of the metrics exposed by Loki and their descriptions, in the sections below. + +You can find a complete list of the exposed metrics by checking the `/metrics` endpoint. + +`http://:/metrics` + +For example: + +[http://localhost:3100/metrics](http://localhost:3100/metrics) + +Both Grafana Loki and Promtail expose a `/metrics` endpoint that expose Prometheus metrics (the default port is 3100 for Loki and 80 for Promtail). You will need a local Prometheus and add Loki and Promtail as targets. See [configuring Prometheus](https://prometheus.io/docs/prometheus/latest/configuration/configuration) for more information. + +All components of Loki expose the following metrics: + +| Metric Name | Metric Type | Description | +| ---------------------------------- | ----------- | ----------------------------------------------------------------------- | +| `loki_internal_log_messages_total` | Counter | Total number of log messages created by Loki itself. | +| `loki_request_duration_seconds` | Histogram | Number of received HTTP requests. | + +Note that most of the metrics are counters and should continuously increase during normal operations. + +1. Your app emits a log line to a file that is tracked by Promtail. +1. Promtail reads the new line and increases its counters. +1. Promtail forwards the log line to a Loki distributor, where the received + counters should increase. +1. The Loki distributor forwards the log line to a Loki ingester, where the + request duration counter should increase. + +If Promtail uses any pipelines with metrics stages, those metrics will also be +exposed by Promtail at its `/metrics` endpoint. See Promtail's documentation on +[Pipelines](https://grafana.com/docs/loki//send-data/promtail/pipelines/) for more information. + +### Metrics cardinality + +Some of the Loki observability metrics are emitted per tracked file (active), with the file path included in labels. This increases the quantity of label values across the environment, thereby increasing cardinality. Best practices with Prometheus labels discourage increasing cardinality in this way. Review your emitted metrics before scraping with Prometheus, and configure the scraping to avoid this issue. + +## Example Loki log line: metrics.go + +Loki emits a "metrics.go" log line from the Querier, Query frontend and Ruler components, which lets you inspect query and recording rule performance. This is an example of a detailed log line "metrics.go" for a query. + +Example log + +`level=info ts=2024-03-11T13:44:10.322919331Z caller=metrics.go:143 component=frontend org_id=mycompany latency=fast query="sum(count_over_time({kind=\"auditing\"} | json | user_userId =`` [1m]))" query_type=metric range_type=range length=10m0s start_delta=10m10.322900424s end_delta=10.322900663s step=1s duration=47.61044ms status=200 limit=100 returned_lines=0 throughput=9.8MB total_bytes=467kB total_entries=1 queue_time=0s subqueries=2 cache_chunk_req=1 cache_chunk_hit=1 cache_chunk_bytes_stored=0 cache_chunk_bytes_fetched=14394 cache_index_req=19 cache_index_hit=19 cache_result_req=1 cache_result_hit=1` + +You can use the query-frontend `metrics.go` lines to understand a query’s overall performance. The “metrics.go” line output by the Queriers contains the same information as the Query frontend but is often more helpful in understanding and troubleshooting query performance. This is largely because it can tell you how the querier spent its time executing the subquery. Here are the most useful stats: + +- **total_bytes**: how many total bytes the query processed +- **duration**: how long the query took to execute +- **throughput**: total_bytes/duration +- **total_lines**: how many total lines the query processed +- **length**: how much time the query was executed over +- **post_filter_lines**: how many lines matched the filters in the query +- **cache_chunk_req**: total number of chunks fetched for the query (the cache will be asked for every chunk so this is equivalent to the total chunks requested) +- **splits**: how many pieces the query was split into based on time and split_queries_by_interval +- **shards**: how many shards the query was split into + +For more information, refer to the blog post [The concise guide to Loki: How to get the most out of your query performance](https://grafana.com/blog/2023/12/28/the-concise-guide-to-loki-how-to-get-the-most-out-of-your-query-performance/). + +### Configure Logging Levels + +To change the configuration for Loki logging levels, update log_level configuration parameter in your `config.yaml` file. + +```yaml +# Only log messages with the given severity or above. Valid levels: [debug, +# info, warn, error] +# CLI flag: -log.level +[log_level: | default = "info"] +``` diff --git a/docs/sources/operations/meta-monitoring/mixins.md b/docs/sources/operations/meta-monitoring/mixins.md new file mode 100644 index 0000000000000..166f2e97fea3a --- /dev/null +++ b/docs/sources/operations/meta-monitoring/mixins.md @@ -0,0 +1,189 @@ +--- +title: Install Loki mixins +menuTitle: Install mixins +description: Describes the Loki mixins, how to configure and install the dashboards, alerts, and recording rules. +weight: 100 +--- + +# Install Loki mixins + +Loki is instrumented to expose metrics about itself via the `/metrics` endpoint, designed to be scraped by Prometheus. Each Loki release includes a mixin. The Loki mixin provides a set of Grafana dashboards, Prometheus recording rules and alerts for monitoring Loki. + +To set up monitoring using the mixin, you need to: + +- Deploy an instance of Prometheus (or a Prometheus-compatible time series database, like [Mimir](https://grafana.com/docs/mimir/latest/)) which can store Loki metrics. +- Deploy an agent, such as Grafana Alloy, or Grafana Agent, to scrape Loki metrics. +- Set up Grafana to visualize Loki metrics, by installing the dashboards. +- Install the recording rules and alerts into Prometheus using `mimirtool`. + +This procedure assumes that you have set up Loki using the Helm chart. + +{{< admonition type="note" >}} +Be sure to update the commands and configuration to match your own deployment. +{{< /admonition >}} + +## Before you begin + +To make full use of the Loki mixin, you’ll need the following running in your environment: + +- Loki instance - A Loki instance which you want to monitor. +- Grafana - For visualizing logs and metrics ([install on Kubernetes](https://grafana.com/docs/grafana/latest/setup-grafana/installation/kubernetes/#deploy-grafana-oss-on-kubernetes)). +- Prometheus or Mimir - An instance of Prometheus or Mimir which will store metrics from Loki. + +To scrape metrics from Loki, you can use Grafana Alloy or the OpenTelemetry Collector. This procedure provides examples only for Grafana Alloy. + +If you have installed Loki using a Helm Chart, this documentation assumes that the Loki and Grafana instances are located on the same Kubernetes cluster. + +## Configure Alloy to scrape Loki metrics + +Loki exposes Prometheus metrics from all of its components to allow meta-monitoring. To retrieve these metrics, you need to configure a suitable scraper. Grafana Alloy can collect metrics and act as a Prometheus scraper. To use this capability, you need to configure Alloy to scrape from all of the components. + +{{< admonition type="tip" >}} +If you're running on Kubernetes, you can use the Kubernetes Monitoring Helm chart. +{{< /admonition >}} + +To scrape metrics from Loki, follow these steps: + +Install Grafana Alloy using the provided instructions for your platform. + +- [Standalone](https://grafana.com/docs/alloy/latest/get-started/install/binary/) +- [Kubernetes](https://grafana.com/docs/alloy/latest/get-started/install/kubernetes/) +- [Docker](https://grafana.com/docs/alloy/latest/get-started/install/docker/) + +Add a configuration block to scrape metrics from your Loki component instances and forward to a Prometheus or Mimir instance. + +- On Kubernetes, you can use the Alloy `discovery.kubernetes` component to discover Loki Pods to scrape metrics from. +- On non-Kubernetes deployments, you may use `prometheus.scrape` and an explicit list of targets to discover Loki instances to scrape. + +For an example, see [Collect and forward Prometheus metrics](https://grafana.com/docs/alloy/latest/tasks/collect-prometheus-metrics/). + +## Configure Grafana + +In your Grafana instance, you'll need to [create a Prometheus datasource](https://grafana.com/docs/grafana/latest/datasources/prometheus/configure-prometheus-data-source/) to visualize the metrics scraped from your Loki cluster. + +## Install Loki dashboards in Grafana + +After Loki metrics are scraped by Grafana Alloy and stored in a Prometheus compatible time-series database, you can monitor Loki’s operation using the Loki mixin. + +Each Loki release includes a mixin that includes: + +- Relevant dashboards for overseeing the health of Loki as a whole, as well as its individual Loki components +- [Recording rules](https://grafana.com/docs/loki/latest/alert/#recording-rules) that compute metrics that are used in the dashboards +- Alerts that trigger when Loki generates metrics that are outside of normal parameters + +To install the mixins in Grafana and Mimir, the general steps are as follows: + +1. Download the mixin dashboards from the Loki repository. + +1. Import the dashboards in your Grafana instance. + +1. Upload `alerts.yaml` and `rules.yaml` files to Prometheus or Mimir with `mimirtool`. + +### Download the `loki-mixin` dashboards + +1. First, clone the Loki repository from Github: + + ```bash + git clone https://github.com/grafana/loki + cd loki + ``` + +1. Once you have a local copy of the repository, navigate to the `production/loki-mixin-compiled-ssd` directory. + + ```bash + cd production/loki-mixin-compiled-ssd + ``` + + OR, if you're deploying Loki in microservices mode: + + ```bash + cd production/loki-mixin-compiled + ``` + +This directory contains a compiled version of the alert and recording rules, as well as the dashboards. + +{{< admonition type="note" >}} +If you want to change any of the mixins, make your updates in the `production/loki-mixin` directory. +Use the instructions in the [README](https://github.com/grafana/loki/tree/main/production/loki-mixin) in that directory to regenerate the files. +{{< /admonition >}} + +### Import the dashboards to Grafana + +The `dashboards` directory includes the monitoring dashboards that can be installed into your Grafana instance. +Refer to [Import a dashboard](https://grafana.com/docs/grafana/latest/dashboards/build-dashboards/import-dashboards/) in the Grafana documentation. + +{{< admonition type="tip" >}} +Install all dashboards. +You can only import one dashboard at a time. +Create a new folder in the Dashboards area, for example “Loki Monitoring”, as an easy location to save the imported dashboards. +{{< /admonition >}} + +To create a folder: + +1. Open your Grafana instance and select **Dashboards**. +1. Click the **New** button. +1. Select **New folder** from the **New** menu. +1. Name your folder, for example, “Loki Monitoring”. +1. Click **Create**. + +To import a dashboard: + +1. Open your Grafana instance and select **Dashboards**. +1. Click the **New** button. +1. Select **Import** from the **New** menu. +1. On the **Import dashboard** screen, select **Upload dashboard JSON file.** +1. Browse to `production/loki-mixin-compiled-ssd/dashboards` and select the dashboard to import. Or, drag the dashboard file, for example, `loki-operational.json`, onto the **Upload** area of the **Import dashboard** screen. +1. Select a folder in the **Folder** menu where you want to save the imported dashboard. For example, select "Loki Monitoring" created in the earlier steps. +1. Click **Import**. + +The imported files are listed in the Loki Monitoring dashboard folder. + +To view the dashboards in Grafana: + +1. Select **Dashboards** in your Grafana instance. +1. Select **Loki Monitoring**, or the folder where you uploaded the imported dashboards. +1. Select any file in the folder to view the dashboard. + +### Add alerts and recording rules to Prometheus or Mimir + +The rules and alerts need to be installed into a Prometheus instance, Mimir or a Grafana Enterprise Metrics cluster. + +You can find the YAML files for alerts and rules in the following directories in the Loki repo: + +For SSD mode: +`production/loki-mixin-compiled-ssd/alerts.yaml` +`production/loki-mixin-compiled-ssd/rules.yaml` + +For microservices mode: +`production/loki-mixin-compiled/alerts.yaml` +`production/loki-mixin-compiled/rules.yaml` + +You use `mimirtool` to load the mixin alerts and rules definitions into a Prometheus instance, Mimir or a Grafana Enterprise Metrics cluster. + +1. Download [mimirtool](https://github.com/grafana/mimir/releases). + +1. Using the details of a Prometheus instance or Mimir cluster, run the following command to load the recording rules: + + ```bash + mimirtool rules load --address=http://prometheus:9090 rules.yaml + ``` + + Or, for example if your Mimir cluster requires an API key, as is the case with Grafana Enterprise Metrics: + + ```bash + mimirtool rules load --id= --address=http://: --key="" rules.yaml + ``` + +1. To load alerts: + + ```bash + mimirtool alertmanager load --address=http://prometheus:9090 alerts.yaml + ``` + + or + + ```bash + mimirtool alertmanager load --id= --address=http://: --key="" alerts.yaml + ``` + +Refer to the [mimirtool](https://grafana.com/docs/mimir/latest/manage/tools/mimirtool/) documentation for more information. diff --git a/docs/sources/operations/observability.md b/docs/sources/operations/observability.md deleted file mode 100644 index 8f617bcf869dc..0000000000000 --- a/docs/sources/operations/observability.md +++ /dev/null @@ -1,114 +0,0 @@ ---- -title: Observability -menuTitle: -description: Observing Grafana Loki -weight: ---- -# Observability - -Both Grafana Loki and Promtail expose a `/metrics` endpoint that expose Prometheus -metrics (the default port is 3100 for Loki and 80 for Promtail). You will need -a local Prometheus and add Loki and Promtail as targets. See [configuring -Prometheus](https://prometheus.io/docs/prometheus/latest/configuration/configuration) -for more information. - -All components of Loki expose the following metrics: - -| Metric Name | Metric Type | Description | -| ---------------------------------- | ----------- | ---------------------------------------------------------------------------------------------------------------------------- | -| `loki_log_messages_total` | Counter | DEPRECATED. Use internal_log_messages_total for the same functionality. Total number of log messages created by Loki itself. | -| `loki_internal_log_messages_total` | Counter | Total number of log messages created by Loki itself. | -| `loki_request_duration_seconds` | Histogram | Number of received HTTP requests. | - -The Loki Distributors expose the following metrics: - -| Metric Name | Metric Type | Description | -| ------------------------------------------------- | ----------- | ------------------------------------------------------------------------------------------------------------------------------------ | -| `loki_distributor_ingester_appends_total` | Counter | The total number of batch appends sent to ingesters. | -| `loki_distributor_ingester_append_failures_total` | Counter | The total number of failed batch appends sent to ingesters. | -| `loki_distributor_bytes_received_total` | Counter | The total number of uncompressed bytes received per both tenant and retention hours. | -| `loki_distributor_lines_received_total` | Counter | The total number of log _entries_ received per tenant (not necessarily of _lines_, as an entry can have more than one line of text). | - -The Loki Ingesters expose the following metrics: - -| Metric Name | Metric Type | Description | -| -------------------------------------------- | ----------- | --------------------------------------------------------------------------------------------------------- | -| `loki_ingester_flush_queue_length` | Gauge | The total number of series pending in the flush queue. | -| `loki_chunk_store_index_entries_per_chunk` | Histogram | Number of index entries written to storage per chunk. | -| `loki_ingester_memory_chunks` | Gauge | The total number of chunks in memory. | -| `loki_ingester_memory_streams` | Gauge | The total number of streams in memory. | -| `loki_ingester_chunk_age_seconds` | Histogram | Distribution of chunk ages when flushed. | -| `loki_ingester_chunk_encode_time_seconds` | Histogram | Distribution of chunk encode times. | -| `loki_ingester_chunk_entries` | Histogram | Distribution of lines per-chunk when flushed. | -| `loki_ingester_chunk_size_bytes` | Histogram | Distribution of chunk sizes when flushed. | -| `loki_ingester_chunk_utilization` | Histogram | Distribution of chunk utilization (filled uncompressed bytes vs maximum uncompressed bytes) when flushed. | -| `loki_ingester_chunk_compression_ratio` | Histogram | Distribution of chunk compression ratio when flushed. | -| `loki_ingester_chunk_stored_bytes_total` | Counter | Total bytes stored in chunks per tenant. | -| `loki_ingester_chunks_created_total` | Counter | The total number of chunks created in the ingester. | -| `loki_ingester_chunks_stored_total` | Counter | Total stored chunks per tenant. | -| `loki_ingester_received_chunks` | Counter | The total number of chunks sent by this ingester whilst joining during the handoff process. | -| `loki_ingester_samples_per_chunk` | Histogram | The number of samples in a chunk. | -| `loki_ingester_sent_chunks` | Counter | The total number of chunks sent by this ingester whilst leaving during the handoff process. | -| `loki_ingester_streams_created_total` | Counter | The total number of streams created per tenant. | -| `loki_ingester_streams_removed_total` | Counter | The total number of streams removed per tenant. | - -The Loki compactor exposes the following metrics: - -| Metric Name | Metric Type | Description | -| ------------------------------------------------------------- | ----------- | ------------------------------------------------------------------------------------------------------- | -| `loki_compactor_delete_requests_processed_total` | Counter | Number of delete requests processed per user. | -| `loki_compactor_delete_requests_chunks_selected_total` | Counter | Number of chunks selected while building delete plans per user. | -| `loki_compactor_delete_processing_fails_total` | Counter | Number of times the delete phase of compaction has failed. | -| `loki_compactor_load_pending_requests_attempts_total` | Counter | Number of attempts that were made to load pending requests with status. | -| `loki_compactor_oldest_pending_delete_request_age_seconds` | Gauge | Age of oldest pending delete request in seconds since they are over their cancellation period. | -| `loki_compactor_pending_delete_requests_count` | Gauge | Count of delete requests which are over their cancellation period and have not finished processing yet. | -| `loki_compactor_deleted_lines` | Counter | Number of deleted lines per user. | - -Promtail exposes these metrics: - -| Metric Name | Metric Type | Description | -| ----------------------------------------- | ----------- | ------------------------------------------------------------------------------------------ | -| `promtail_read_bytes_total` | Gauge | Number of bytes read. | -| `promtail_read_lines_total` | Counter | Number of lines read. | -| `promtail_dropped_bytes_total` | Counter | Number of bytes dropped because failed to be sent to the ingester after all retries. | -| `promtail_dropped_entries_total` | Counter | Number of log entries dropped because failed to be sent to the ingester after all retries. | -| `promtail_encoded_bytes_total` | Counter | Number of bytes encoded and ready to send. | -| `promtail_file_bytes_total` | Gauge | Number of bytes read from files. | -| `promtail_files_active_total` | Gauge | Number of active files. | -| `promtail_request_duration_seconds` | Histogram | Number of send requests. | -| `promtail_sent_bytes_total` | Counter | Number of bytes sent. | -| `promtail_sent_entries_total` | Counter | Number of log entries sent to the ingester. | -| `promtail_targets_active_total` | Gauge | Number of total active targets. | -| `promtail_targets_failed_total` | Counter | Number of total failed targets. | - -Most of these metrics are counters and should continuously increase during normal operations: - -1. Your app emits a log line to a file that is tracked by Promtail. -2. Promtail reads the new line and increases its counters. -3. Promtail forwards the log line to a Loki distributor, where the received - counters should increase. -4. The Loki distributor forwards the log line to a Loki ingester, where the - request duration counter should increase. - -If Promtail uses any pipelines with metrics stages, those metrics will also be -exposed by Promtail at its `/metrics` endpoint. See Promtail's documentation on -[Pipelines]({{< relref "../send-data/promtail/pipelines" >}}) for more information. - -An example Grafana dashboard was built by the community and is available as -dashboard [10004](/dashboards/10004). - -## Metrics cardinality - -Some of the Loki observability metrics are emitted per tracked file (active), with the file path included in labels. -This increases the quantity of label values across the environment, thereby increasing cardinality. Best practices with Prometheus [labels](https://prometheus.io/docs/practices/naming/#labels) discourage increasing cardinality in this way. -Review your emitted metrics before scraping with Prometheus, and configure the scraping to avoid this issue. - - -## Mixins - -The Loki repository has a [mixin](https://github.com/grafana/loki/blob/main/production/loki-mixin) that includes a -set of dashboards, recording rules, and alerts. Together, the mixin gives you a -comprehensive package for monitoring Loki in production. - -For more information about mixins, take a look at the docs for the -[monitoring-mixins project](https://github.com/monitoring-mixins/docs). diff --git a/docs/sources/reference/loki-http-api.md b/docs/sources/reference/loki-http-api.md index 2ff10507760b2..b707aa20eeae9 100644 --- a/docs/sources/reference/loki-http-api.md +++ b/docs/sources/reference/loki-http-api.md @@ -1041,7 +1041,7 @@ GET /metrics ``` `/metrics` returns exposed Prometheus metrics. See -[Observing Loki]({{< relref "../operations/observability" >}}) +[Observing Loki]({{< relref "../operations/meta-monitoring" >}}) for a list of exported metrics. In microservices mode, the `/metrics` endpoint is exposed by all components. diff --git a/docs/sources/send-data/promtail/_index.md b/docs/sources/send-data/promtail/_index.md index 03bbf6487c396..ca268d872f6bb 100644 --- a/docs/sources/send-data/promtail/_index.md +++ b/docs/sources/send-data/promtail/_index.md @@ -164,7 +164,7 @@ This endpoint returns 200 when Promtail is up and running, and there's at least ### `GET /metrics` This endpoint returns Promtail metrics for Prometheus. Refer to -[Observing Grafana Loki]({{< relref "../../operations/observability" >}}) for the list +[Observing Grafana Loki]({{< relref "../../operations/meta-monitoring" >}}) for the list of exported metrics. ### Promtail web server config diff --git a/docs/sources/setup/install/helm/concepts.md b/docs/sources/setup/install/helm/concepts.md index 581498af89b23..ca2a626421867 100644 --- a/docs/sources/setup/install/helm/concepts.md +++ b/docs/sources/setup/install/helm/concepts.md @@ -19,7 +19,15 @@ This section describes the components installed by the Helm Chart. By default Loki will be installed in the scalable mode. This consists of a read and write component. These can be scaled-out independently. -## Dashboards +By default, the chart installs in [Simple Scalable]({{< relref "./install-scalable" >}}) mode. This is the recommended method for most users. To understand the differences between deployment methods, see the [Loki deployment modes]({{< relref "../../../get-started/deployment-modes" >}}) documentation. + +## Monitoring Loki + +The Loki Helm chart does not deploy self-monitoring by default. Loki clusters can be monitored using the meta-monitoring stack, which monitors the logs, metrics, and traces of the Loki cluster. There are two deployment options for this stack, see the installation instructions within [Monitoring]({{< relref "./monitor-and-alert" >}}). + +{{< admonition type="note" >}} +The meta-monitoring stack replaces the monitoring section of the Loki helm chart which is now **DEPRECATED**. See the [Monitoring]({{< relref "./monitor-and-alert" >}}) section for more information. +{{< /admonition >}} This chart includes dashboards for monitoring Loki. These require the scrape configs defined in the `monitoring.serviceMonitor` and `monitoring.selfMonitoring` sections described below. The dashboards are deployed via a config map which can be mounted on a Grafana instance. The Dashboard requires an installation of the Grafana Agent and the Prometheus operator. The agent is installed with this chart.