Upgrade Redis Enterprise for Kubernetes
Redis implements rolling updates for software upgrades in Kubernetes deployments. The upgrade process includes updating three components:
- Upgrade the Redis Enterprise operator
- Upgrade the Redis Enterprise cluster (REC)
- Upgrade Redis Enterprise databases (REDB)
Prerequisite
Check Supported Kubernetes distributions to make sure your Kubernetes distribution is supported.
Use
kubectl get recand verify theLICENSE STATEis valid on your REC before you start the upgrade process.Verify you are upgrading from Redis Enterprise operator version 6.2.10-45 or later. If you are not, you must upgrade to 6.2.10-45 before upgrading to versions 6.2.18 or later.
Upgrade the operator
Download the bundle
Make sure you pull the correct version of the bundle. You can find the version tags by checking the operator releases on GitHub or by using the GitHub API.
You can download the bundle for the latest release with the following curl command:
VERSION=`curl --silent https://api.github.com/repos/RedisLabs/redis-enterprise-k8s-docs/releases/latest | grep tag_name | awk -F'"' '{print $4}'`
curl --silent -O https://raw.githubusercontent.com/RedisLabs/redis-enterprise-k8s-docs/$VERSION/bundle.yaml
If you need a different release, replace VERSION in the above with a specific release tag.
Apply the bundle
Apply the bundle to deploy the new operator binary. This will also apply any changes in the new release to custom resource definitions, roles, role binding, or operator service accounts.
Upgrade the bundle and operator with a single command, passing in the bundle YAML file:
kubectl apply -f bundle.yaml
After running this command, you should see a result similar to this:
role.rbac.authorization.k8s.io/redis-enterprise-operator configured
serviceaccount/redis-enterprise-operator configured
rolebinding.rbac.authorization.k8s.io/redis-enterprise-operator configured
customresourcedefinition.apiextensions.k8s.io/redisenterpriseclusters.app.redislabs.com configured
customresourcedefinition.apiextensions.k8s.io/redisenterprisedatabases.app.redislabs.com configured
deployment.apps/redis-enterprise-operator configured
Reapply the admission controller webhook
If you have the admission controller enabled, you need to manually reapply the ValidatingWebhookConfiguration.
Versions 6.4.2 and later uses a new ValidatingWebhookConfiguration resource to replace redb-admission. To use newer releases, delete the old webhook resource and apply the new file.
Delete the existing
ValidatingWebhookConfigurationon the Kubernetes cluster (namedredb-admission).kubectl delete ValidatingWebhookConfiguration redb-admissionApply the resource from the new file.
kubectl apply -f deploy/admission/webhook.yaml
Verify the
admission-tlssecret exists.kubectl get secret admission-tlsThe output should look similar to
NAME TYPE DATA AGE admission-tls Opaque 2 2m43sSave the certificate to a local environment variable.
CERT=`kubectl get secret admission-tls -o jsonpath='{.data.cert}'`Create a Kubernetes validating webhook, replacing
<namespace>with the namespace where the REC was installed.The
webhook.yamltemplate can be found in redis-enterprise-k8s-docs/admissionsed 's/OPERATOR_NAMESPACE/<namespace>/g' webhook.yaml | kubectl create -f -Create a patch file for the Kubernetes validating webhook.
cat > modified-webhook.yaml <<EOF webhooks: - name: redisenterprise.admission.redislabs clientConfig: caBundle: $CERT admissionReviewVersions: ["v1beta1"] EOFPatch the webhook with the certificate.
kubectl patch ValidatingWebhookConfiguration \ redis-enterprise-admission --patch "$(cat modified-webhook.yaml)"
Verify the operator is running
You can check your deployment to verify the operator is running in your namespace.
kubectl get deployment/redis-enterprise-operator
You should see a result similar to this:
NAME READY UP-TO-DATE AVAILABLE AGE
redis-enterprise-operator 1/1 1 1 0m36s
Upgrade the Redis Enterprise cluster (REC)
Verify your license is valid before upgrading. Invalid licenses will cause the upgrade to fail.
Use kubectl get rec and verify the LICENSE STATE is valid on your REC before you start the upgrade process.
The Redis Enterprise cluster (REC) can be updated automatically or manually. To trigger automatic upgrade of the REC after the operator upgrade completes, specify autoUpgradeRedisEnterprise: true in your REC spec. If you don’t have automatic upgrade enabled, follow the below steps for the manual upgrade.
Before beginning the upgrade of the Redis Enterprise cluster, check the K8s operator release notes to find the Redis Enterprise image tag. For example, in Redis Enterprise K8s operator release 6.0.12-5, the Images section shows the Redis Enterprise tag is 6.0.12-57.
After the operator upgrade is complete, you can upgrade Redis Enterprise cluster (REC).
Edit redisEnterpriseImageSpec in the REC spec
Edit the REC custom resource YAML file.
kubectl edit rec <your-rec.yaml>Replace the
versionTag:declaration underredisEnterpriseImageSpecwith the new version tag.spec: redisEnterpriseImageSpec: imagePullPolicy: IfNotPresent repository: redislabs/redis versionTag: <new-version-tag>Save the changes to apply.
Reapply roles and role bindings
If your operator is monitoring multiple namespaces, you’ll need to reapply your role and role bindings for each managed namespace. See Manage databases in multiple namespaces for more details.
Monitor the upgrade
You can view the state of the REC with kubectl get rec.
During the upgrade, the state should be Upgrade.
When the upgrade is complete and the cluster is ready to use, the state will change to Running.
If the state is InvalidUpgrade, there is an error (usually relating to configuration) in the upgrade.
$ kubectl get rec
NAME NODES VERSION STATE SPEC STATUS LICENSE STATE SHARDS LIMIT LICENSE EXPIRATION DATE AGE
rec 3 6.2.10-107 Upgrade Valid Valid 4 2022-07-16T13:59:00Z 92m
To see the status of the current rolling upgrade, run:
kubectl rollout status sts <REC_name>
Upgrade databases
After the cluster is upgraded, you can upgrade your databases. The process for upgrading databases is the same for both Kubernetes and non-Kubernetes deployments. For more details on how to upgrade a database, see the Upgrade an existing Redis Enterprise Software deployment documentation.
Note that if your cluster redisUpgradePolicy or your database redisVersion are set to major, you won’t be able to upgrade those databases to minor versions. See Redis upgrade policy for more details.