Skip to content

ホットアップグレード

ホットアップグレードは、稼働中のEMQX Enterpriseノードを停止せずにパッチバージョンのアップデートを適用できる機能です。アップグレード中も接続は維持され、ノードは次回の再起動時に新しいリリースツリーに切り替わります。

ホットアップグレードはパッチバージョンの差分(バージョン番号の3番目の数字)のみ対応しています。例えば、5.10.4から5.10.5へのアップグレードは対応していますが、5.10.xから5.11.0へのアップグレードは対応していません。

ホットアップグレードはemqx_relupプラグインによって実行されます。プラグインはダッシュボードからインストールします。すべてのアップグレード操作はemqx ctl relup CLIを通じて行います。

重要なお知らせ

ホットアップグレードを実行する前に、data/etc/、およびlog/のバックアップを必ず取得してください。アップグレード適用後のインプレースロールバックはできません。

前提条件

  • 各ノードでEMQX Enterpriseが稼働していること。
  • 各ノードでシェルアクセスがあり、emqx ctlコマンドを実行できること。
  • emqx_relupプラグインのバージョンが現在のEMQX Enterpriseのバージョンと一致していること。
  • プラグインで対象バージョンがサポートされているアップグレードパスに含まれていること(ステップ2で確認)。

ステップ1: emqx_relupプラグインのインストール

ダッシュボードからダッシュボード経由でパッケージをインストールの手順に従いプラグインをインストールします。プラグインパッケージはhttps://packages.emqx.io/emqx-plugins/e<EMQX-VSN>/に公開されています。

インストール後、プラグインはrunningステータスで表示されるはずです。

ステップ2: アップグレードパスのサポート確認

インストール済みプラグインが認識しているバージョンホップを一覧表示します。

bash
emqx ctl relup list-supported-paths

{from, target}のバージョンペアが出力に含まれていることを確認してから次に進んでください。

ステップ3: タールボールとSHA256サイドカーの準備

2つのファイルを各ノードにコピーします。EMQXプロセスが読み取れる任意の場所に配置可能です。

  • emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz:EMQX Enterpriseの対象リリースのタールボール
  • emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz.sha256:タールボールのSHA256ダイジェスト。ダイジェストのみの形式とsha256sumの出力形式(<digest> <filename>)の両方が受け付けられます。
bash
scp emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz      node1:/opt/upgrade/
scp emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz.sha256 node1:/opt/upgrade/

.sha256サイドカーはタールボールと同じディレクトリに置き、同じベース名で拡張子が.sha256である必要があります。

ステップ4: アップグレードの実行

各ノードで、relup upgradeコマンドにタールボールのパスを指定してアップグレードを開始します。

bash
emqx ctl relup upgrade /opt/upgrade/emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz

アップグレードハンドラーは以下の処理を実行します。

  1. SHA256ダイジェストを検証し、不一致の場合は処理を拒否します。
  2. タールボールを展開し、releases/emqx_varsから対象バージョンを読み取ります。
  3. ランタイムのサブディレクトリ(bin/erts-*/lib/releases/)のみを<RootDir>/relup/<TargetVsn>/に展開します。設定、データ、ログ、プラグインは元のインストールルートに残ります。
  4. プラグインの.relupカタログから該当するコード変更指示を適用します。
  5. アップグレード後のコールバックを実行します。
  6. <RootDir>/relup/currentに対象バージョン文字列を書き込みます。

クラスター全体への展開は運用者の責任です。ノードを1台ずつアップグレードし、各ノードの正常性を確認してから次に進んでください。

ステップ5: ノードの検証

アップグレードコマンドが完了したら、ノードの正常性を確認します。

bash
# ノードが稼働中か確認
emqx ctl status

# バージョンマーカーが書き込まれているか確認
cat <RootDir>/relup/current

# アップグレードの状態と履歴を確認
emqx ctl relup status
emqx ctl relup logs

relup/currentには対象バージョン文字列が含まれ、emqx ctl statusはノードが稼働中であることを報告するはずです。

ステップ6: 新リリースへの再起動

コード変更のアップグレードは実行中のVMに即時反映されますが、新しいERTSランタイムとバイナリに完全に切り替えるにはノードを再起動してください。

bash
emqx restart

再起動時、bin/emqxラッパーは<RootDir>/relup/currentを検出し、<RootDir>/relup/<TargetVsn>/から起動します。元の<RootDir>data/etc/log/plugins/の管理を継続します。

ステップ7: クリーンアップ

クラスター全体が対象バージョンで稼働していることを確認したら、ステージングファイルを削除します。

bash
rm /opt/upgrade/emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz
rm /opt/upgrade/emqx-enterprise-<TargetVsn>-<os>-<arch>.tar.gz.sha256

プラグインはソースパスを追跡しないため、プラグイン内部でのクリーンアップは不要です。

ロールバック

適用済みのホップに対するインプレースロールバックはありません。コード変更はライブVM上で実行され、アップグレード後のコールバックでディスク上のデータが変更されている可能性があるため、元に戻すことはサポートされていません。

限定的なリカバリオプションは以下の2つです。

  • 次回再起動前の場合: アップグレードしたコードに問題があるがディスク状態が旧リリースと互換性がある場合、バージョンマーカーを削除して旧ツリーで再起動します。

    bash
    rm <RootDir>/relup/current
    # 必要に応じて: rm -rf <RootDir>/relup/<TargetVsn>/
    emqx restart

    これは起動パスのみを復元します。アップグレードによるライブ状態の変更は既に反映されています。

  • 完全復元: 事前にバックアップしたdata/を復元し、旧EMQXリリースを再インストールします。

これらの制約を踏まえてアップグレードの時間帯を計画してください。

CLIリファレンス

コマンド説明
emqx ctl relup upgrade <TarballPath>指定したタールボールからアップグレードホップを適用します。
emqx ctl relup list-supported-pathsプラグインカタログでサポートされている{from, target}バージョンホップを一覧表示します。
emqx ctl relup status現在のアップグレード状態を表示します:idlein-progress、またはhot-upgraded to <vsn>; pending on restart to boot from the new version
emqx ctl relup logsこのノードのアップグレード履歴を永続ログテーブルから出力します。
emqx ctl relup logs-clearこのノードのアップグレードログテーブルをクリアします。