Prerequisites:
k8s version 1.16+ is installed
Helm version 3 is installed
Hivemq k8s operator repo is already added in helm repo
Expected Result:
Upgrade hivemq version without downtime. Hivemq version 4.6.4 should be running without error using k8s operator version 0.9.2
Steps to follow:
Hivemq cluster values file:
operator values file:
monitoring: enabled: true operator: admissionWebhooks: enabled: false failurePolicy: Fail deployCr: false logLevel: DEBUG
Deploy Hivemq operator with 0.8.7
helm upgrade --install -f operator.yaml <release name> hivemq/hivemq-operator —version 0.8.7
Apply Hivemq cluster with hivemq 4.6.2
Kubectl apply -f <hivemq cluster.yaml>
Simply apply the new CRD using the following command (considering k8s version is 1.16+)
kubectl apply -f https://raw.githubusercontent.com/hivemq/helm-charts/prerelease-4.6.4/charts/hivemq-operator/crds/hivemq-cluster.yaml
Scale operator to 0 so it doesn’t immediately reconcile. This will only remove the operator pod, but leave the HiveMQ nodes as remaining
kubectl scale —replicas=0 deployment <operator name>
Edit hivemq cluster yaml to update the hivemq version as 4.6.4
Apply the changes
Kubectl apply -f <hivemq cluster.yaml>
check the pods status(no errors)
kubectl get pods
Update operaor version i.e 0.9.2 in cluster(operator config File)
Run following command for rolling upgrade
helm upgrade --install -f operator.yaml <release name> hivemq/hivemq-operator —version 0.9.2