Enterprise Open source

Migrate the Helm chart from version 5.x to 6.0

The mimir-distributed Helm chart version 6.0 introduces several breaking changes:

  • Ingest storage and Kafka are enabled by default. The bundled Kafka deployment is for demonstration and testing purposes only and is not suitable for production use.
  • Rollout-operator webhooks are enabled by default, which requires installing CRDs before upgrading.
  • The top-level nginx values section is removed. You must migrate to the unified gateway deployment before upgrading to version 6.0.

Before you begin

  • You are running mimir-distributed Helm chart version 5.x.
  • If you’re using the rollout-operator, you have cluster permissions to install CRDs.
  • If you’re using the top-level nginx values, you have already migrated to the unified gateway deployment.

Procedure

Migrate to unified gateway deployment (if needed)

If your values file contains a top-level nginx section, you must migrate to the unified gateway deployment before upgrading to version 6.0.

Follow the Migrate to unified proxy deployment guide to complete this migration.

Install rollout-operator CRDs (if using rollout-operator)

If you’re using the rollout-operator, install the CRDs from the rollout-operator chart:

Bash
kubectl apply -f https://raw.githubusercontent.com/grafana/helm-charts/main/charts/rollout-operator/crds/replica-templates-custom-resource-definition.yaml
kubectl apply -f https://raw.githubusercontent.com/grafana/helm-charts/main/charts/rollout-operator/crds/zone-aware-pod-disruption-budget-custom-resource-definition.yaml

Choose your ingest storage strategy

Choose one of the following options:

Migrate to ingest storage

If you want to migrate your existing installation to use ingest storage, follow the Migrate from classic to ingest storage architecture guide.

Note

The Kafka deployment included in the Helm chart is for demonstration and testing purposes only. For production deployments, set up your own Kafka-compatible backend and configure Mimir to connect to it.

To use your own Kafka cluster:

  1. Set up a production-grade Kafka-compatible backend (such as Apache Kafka, Amazon MSK, or Confluent Cloud).
  2. Disable the bundled Kafka deployment in your values file:
    YAML
    kafka:
      enabled: false
  3. Configure Mimir to connect to your Kafka cluster. Refer to the Configure the Kafka backend documentation for configuration details.

Continue using classic architecture (disable ingest storage)

Classic architecture is supported in Mimir version 3.0. If you want to continue using the classic architecture without ingest storage, add the following to your values file:

YAML
mimir:
  structuredConfig:
    ingest_storage:
      enabled: false
  ingester:
    push_grpc_method_enabled: true
kafka:
  enabled: false

After adding these values, upgrade to version 6.0.

Upgrade to version 6.0

After completing the prerequisites and choosing your ingest storage strategy, upgrade the Helm release:

Bash
helm upgrade <RELEASE_NAME> grafana/mimir-distributed --version 6.0.2 -f <VALUES_FILE>