Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Draft 2.15 release notes #10165

Merged
merged 8 commits into from
Jan 3, 2025
Merged
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
128 changes: 128 additions & 0 deletions docs/sources/mimir/release-notes/v2.15.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,128 @@
---
title: "Grafana Mimir version 2.15 release notes"
menuTitle: "V2.15 release notes"
description: "Release notes for Grafana Mimir version 2.15"
weight: 1100
---

# Grafana Mimir version 2.15 release notes

<!-- vale Grafana.GoogleWill = NO -->
<!-- vale Grafana.Timeless = NO -->
<!-- Release notes are often future focused -->

Grafana Labs is excited to announce version 2.15 of Grafana Mimir.

The highlights that follow include the top features, enhancements, and bug fixes in this release.
For the complete list of changes, refer to the [CHANGELOG](https://github.com/grafana/mimir/blob/main/CHANGELOG.md).

## Features and enhancements

S2 compression for gRPC is now supported using the following flags:

- `-alertmanager.alertmanager-client.grpc-compression=s2`
- `-ingester.client.grpc-compression=s2`
- `-querier.frontend-client.grpc-compression=s2`
- `-querier.scheduler-client.grpc-compression=s2`
- `-query-frontend.grpc-client-config.grpc-compression=s2`
- `-query-scheduler.grpc-client-config.grpc-compression=s2`
- `-ruler.client.grpc-compression=s2`
- `-ruler.query-frontend.grpc-client-config.grpc-compression=s2`

Distributors now support `lz4` OTLP compression, and can be deployed in multiple availability zones.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The ruler's `<prometheus-http-prefix>/api/v1/rules` endpoint now supports `exclude_alerts`, `group_limit`, and `group_next_token` parameters.
chencs marked this conversation as resolved.
Show resolved Hide resolved

mimirtool's analyze ruler/prometheus commands now support bearer tokens.
chencs marked this conversation as resolved.
Show resolved Hide resolved

HTTP client settings can now be tuned for GCS and Azure backends via an `http` block or corresponding CLI flags.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The compactor now refreshes deletion marks concurrently when updating the bucket index.

The number of Memcached replicas for each type of cache can now be set using configuration settings when using jsonnet.
chencs marked this conversation as resolved.
Show resolved Hide resolved

## Important changes

In Grafana Mimir 2.15, the following behavior has changed:

The following alertmanager metrics are not exported for a `user` when the metric value is zero:
chencs marked this conversation as resolved.
Show resolved Hide resolved

- `cortex_alertmanager_alerts_received_total`
- `cortex_alertmanager_alerts_invalid_total`
- `cortex_alertmanager_partial_state_merges_total`
- `cortex_alertmanager_partial_state_merges_failed_total`
- `cortex_alertmanager_state_replication_total`
- `cortex_alertmanager_state_replication_failed_total`
- `cortex_alertmanager_alerts`
- `cortex_alertmanager_silences`

PromQL compatibility has been upgraded from Prometheus 2.0 to 3.0. More details can be found in the [Prometheus documentation](https://prometheus.io/docs/prometheus/3.0/migration/#promql). The following changes are of note:
chencs marked this conversation as resolved.
Show resolved Hide resolved

- The `.` pattern in regular expressions in PromQL now matches newline characters.
- Lookback and range selectors are left open and right closed (previously left closed and right closed).
chencs marked this conversation as resolved.
Show resolved Hide resolved
- Native histograms now use exponential interpolation.

Backwards compatibility in dashboards and alerts for `thanos_memcached_`-prefixed metrics has been removed. These metrics were removed in 2.12 in favor of `thanos_cache_`-prefixed metrics.

Experimental support for Redis as a cache backend has been removed from jsonnet.

The following deprecated configuration options were removed in this release:

- `-distributor.direct-otlp-translation-enabled`, which has been enabled by default since 2.13 and is now considered stable.
- `-query-scheduler.prioritize-query-components`, which is always enabled now
chencs marked this conversation as resolved.
Show resolved Hide resolved
- `-ingest-storage.kafka.ongoing-records-per-fetch` and `-ingest-storage.kafka.startup-records-per-fetch`, which have been removed in favour of `-ingest-storage.kafka.max-buffered-bytes`
chencs marked this conversation as resolved.
Show resolved Hide resolved
chencs marked this conversation as resolved.
Show resolved Hide resolved
- `-api.get-request-for-ingester-shutdown-enabled`, a deprecated experimental flag which has been marked for removal in 2.15.

## Experimental features

Grafana Mimir 2.15 includes some features that are experimental and disabled by default.
Use these features with caution and report any issues that you encounter:

Mimir's experimental PromQL engine can now be enabled with `-querier.query-engine=mimir`. This new engine provides improved performance and reduced querier resource consumption; however, it supports only a subset of all PromQL features. It will fall back to Prometheus' engine for queries containing unsupported features.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The query-frontend can now cache non-transient errors using the experimental flags `-query-frontend.cache-errors` and `-query-frontend.results-cache-ttl-for-errors`.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The query-frontend and querier both support an experimental PromQL function, `double_exponential_smoothing`, which can be enabled by setting `-querier.promql-experimental-functions-enabled=true` and `-query-frontend.promql-experimental-functions-enabled=true`.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The ingester can now support out-of-order native histogram ingestion via the flag `-ingester.ooo-native-histograms-ingestion-enabled`.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The ingester can now build 24h blocks for out-of-order data which is >24h old, using the setting `-blocks-storage.tsdb.bigger-out-of-order-blocks-for-old-samples`.
chencs marked this conversation as resolved.
Show resolved Hide resolved

The ruler now supports caching the contents of rule groups via the setting `-ruler-storage.cache.rule-group-enabled`.

The distributor now supports promotion of OTel resource attributes to labels via the setting `-distributor.promote-otel-resource-attributes`.

## Bug fixes

- Alerts: Fix autoscaling metrics joins in `MimirAutoscalerNotActive` when series churn.
- Alerts: Exclude failed cache "add" operations from alerting since failures are expected in normal operation.
- Alerts: Exclude read-only replicas from `IngesterInstanceHasNoTenants` alert.
- Alerts: Use resident set memory for the `EtcdAllocatingTooMuchMemory` alert so that ephemeral file cache memory doesn't cause the alert to misfire.
- Dashboards: Fix autoscaling metrics joins when series churn.
- Distributor: Fix pooling buffer reuse logic when `-distributor.max-request-pool-buffer-size` is set.
- Ingester: Fix issue where active series requests error when encountering a stale posting.
- Ingester: Fix race condition in per-tenant TSDB creation.
- Ingester: Fix race condition in exemplar adding.
- Ingester: Fix race condition in native histogram appending.
- Ingester: Fix bug in concurrent fetching where a failure to list topics on startup would cause to use an invalid topic ID (0x00000000000000000000000000000000).
chencs marked this conversation as resolved.
Show resolved Hide resolved
- Ingester: Fix data loss bug in the experimental ingest storage when a Kafka Fetch is split into multiple requests and some of them return an error.
- Ingester: Fix bug where chunks could have one unnecessary zero byte at the end.
- OTLP: Support integer exemplar value type.
- OTLP receiver: Preserve colons and combine multiple consecutive underscores into one when generating metric names in suffix adding mode (`-distributor.otel-metric-suffixes-enabled`).
- Prometheus: Fix issue where negation of native histograms (e.g. `-some_native_histogram_series`) did nothing.
- Prometheus: Always return unknown hint for first sample in non-gauge native histograms chunk to avoid incorrect counter reset hints when merging chunks from different sources.
- Prometheus: Ensure native histograms counter reset hints are corrected when merging results from different sources.
- PromQL: Fix issue where functions such as `rate()` over native histograms could return incorrect values if a float stale marker was present in the selected range.
- PromQL: `round` now removes the metric name again.
- PromQL: Fix issue where `metric might not be a counter, name does not end in _total/_sum/_count/_bucket` annotation would be emitted even if `rate` or `increase` did not have enough samples to compute a result.
- Querier: Fix the behaviour of binary operators between native histograms and floats.
chencs marked this conversation as resolved.
Show resolved Hide resolved
- Querier: Fix stddev+stdvar aggregations to always ignore native histograms, and to treat Infinity consistently.
chencs marked this conversation as resolved.
Show resolved Hide resolved
- Query-frontend: Fix issue where sharded queries could return annotations with incorrect or confusing position information.
- Query-frontend: Fix issue where downstream consumers may not generate correct cache keys for experimental error caching.
- Query-frontend: Support `X-Read-Consistency-Offsets` on labels queries too.
- Ruler: Fix issue when using the experimental `-ruler.max-independent-rule-evaluation-concurrency` feature, where the ruler could panic as it updates a running ruleset or shutdowns.

### Helm chart improvements

The Grafana Mimir and Grafana Enterprise Metrics Helm charts are released independently.
Refer to the [Grafana Mimir Helm chart documentation](/docs/helm-charts/mimir-distributed/latest/).
Loading