EMQX Operator のアップグレード
このページでは、EMQX Operator を最新バージョン 2.3.0 にアップグレードする手順を説明します。
EMQX Operator 2.2.x から 2.3.0 へのアップグレード
アップグレードを開始する前に、すべての EMQX カスタムリソースが
v2beta1API バージョンを使用していることを確認してください。EMQX Operator 2.3.0 はv2beta1より前の API バージョンをサポートしていません。リソースがまだ
v2alpha1またはv1beta4API バージョンを使用している場合は、v2beta1に更新してください。ほとんどの場合、apiVersionフィールドをパッチすることで対応可能です。shkubectl patch emqx emqx --type=merge -p '{"apiVersion":"apps.emqx.io/v2beta1"}'既存の EMQX CRD に対して、変換用の webhook を明示的に削除するパッチを適用します。
shkubectl patch crd emqxes.apps.emqx.io --type=json -p='[{"op":"replace", "path":"/spec/conversion", "value":{"strategy":"None"}}]' kubectl patch crd rebalances.apps.emqx.io --type=json -p='[{"op":"replace", "path":"/spec/conversion", "value":{"strategy":"None"}}]'EMQX CRD のパッチ適用後、既存のコントローラーマネージャーのデプロイメントおよび関連リソースを削除します。
shkubectl delete --ignore-not-found clusterrole emqx-operator-manager-role kubectl delete --ignore-not-found clusterrolebinding emqx-operator-manager-rolebinding kubectl delete --ignore-not-found mutatingwebhookconfiguration emqx-operator-mutating-webhook-configuration kubectl delete --ignore-not-found validatingwebhookconfiguration emqx-operator-validating-webhook-configuration kubectl delete --ignore-not-found namespace emqx-operator-system必要に応じて、レガシー CRD を削除します。
shkubectl delete --ignore-not-found crd emqxbrokers.apps.emqx.io emqxenterprises.apps.emqx.io emqxplugins.apps.emqx.ioインストール手順 に従って、新しい EMQX Operator をデプロイします。