ADR 0006 - Bitnami Helm Chart for Redis

Author

Simon Beck

Owner

Schedar

Reviewers

Schedar

Date Created

2022-12-27

Date Updated

2023-01-04

Status

implemented

Tags

redis,service

Summary

We use the Redis Bitnami Helm Chart and deploy it with the Crossplane Provider Kubernetes.

Problem

We need to provide Redis on Kubernetes with following features:

  • Standalone and Cluster functionality (sentinel)

  • Ability to customize Redis settings

  • Included metrics exporter

  • Backup

  • Regular Maintenance

  • Version Upgrades

Solutions

For Redis there are a few operators available. As well as the Bitnami Helm charts.

The following section contains the operators that have been looked at.

Requirements IBM Operator Spotathome Opstree Bitnami Helmchart

Sentinel and Standalone

❌ no sentinel

❌ no sentinel

Customize Redis Settings

Metrics

Backup

Regular Maintenance

Version Upgrades

Some additional Notes:

  • The IBM Operator is in a very early development stage

  • The Spotathome Operator feels the most mature so far, from the other operators

  • Backup and regular maintenance have to be engineered no matter what solution is chosen

  • The possibility of our own operator was discussed, but with the experience from the PostgreSQL operator, was quickly dismissed

Decision

The instantiation of the Helm Charts will be handled by provider-kubernetes.

Advantages
  • Less complexity than operators, but provides the same features

  • Have been used in SPKS for years now

Disadvantages
  • Bitnami had breaking changes in the past, so we probably run into these in the future as well

If a breaking change occurs there are currently two ideas how to tackle them:

  • Fork the chart and maintain it ourselves

  • Grandfathering out the old chart version. Any new instances will use the new chart and existing ones use the old one.

Further details will be explored in case of breaking changes.

Rationale

Operators add one more layer of complexity to the setup and one more part that can break. In order to justify this added complexity the operators should provide more functionality than a simple Helm Chart. If the functionality of the operators is extended in the future, we can re-evaluate our decision and devise a migration path.

With experience from SPKS we know how the Bitnami Helm Chart works and that it’s capable of satisfying our requirements.