Skip to content

プラグイン管理

このページでは、EMQXにおけるプラグインのライフサイクルについて説明し、Dashboard、CLI、REST APIを使用してプラグインのインストール、設定、起動、停止、アンインストール、アップグレードを行う方法を解説します。

プラグインのライフサイクル

EMQXのプラグインは、主に以下の3つのライフサイクル状態を経ます。

  • インストール済み:プラグインのコードと設定が読み込まれているが、アプリケーションはまだ起動していない状態。
  • 起動済み:プラグインが実行中で、EMQXと積極的に連携している状態。
  • アンインストール済み:プラグインがシステムから完全に削除された状態。

インストール手順

インストールの流れは以下の通りです。

  1. プラグインパッケージ(make rel コマンドで作成されたtarball)をDashboard、API、またはCLI経由でアップロードします。詳細なインストール手順はプラグインのインストールと管理を参照してください。
  2. プラグインパッケージはEMQXクラスターの各ノードに転送されます。
  3. 各ノード上で以下の処理が行われます:
    • tarballがEMQXルートディレクトリのpluginsサブディレクトリに保存されます(plugins.install_dirオプションで上書き可能):$EMQX_ROOT/plugins/my_emqx_plugin-1.0.0.tar.gz
    • 同じディレクトリに展開されます:$EMQX_ROOT/plugins/my_emqx_plugin-1.0.0/
    • 初期設定(メインプラグインのappからのconfig.hocon)が$EMQX_DATA_DIR/plugins/my_emqx_plugin/config.hoconにコピーされます。
    • Avroスキーマが存在する場合は検証のためにロードされます。
    • プラグインコードがノードにロードされますが、アプリケーションは起動されません。
    • プラグインはEMQX設定のplugins.statesdisabledとして登録されます。

TIP

プラグインの状態はEMQX設定内のenableフラグ(trueまたはfalse)のみが保存されます。プラグインの完全な設定は各ノードの$EMQX_DATA_DIR/plugins/my_emqx_plugin/config.hoconファイルに保持されています。

設定

インストール後、プラグインの設定はDashboardやAPIを通じて更新できます。

  • 新しい設定はAvroスキーマ(存在する場合)に基づいて検証されます。
  • 更新内容はクラスター内の全ノードに配布されます。
  • プラグインのon_config_changed/2コールバック関数が呼び出されます。プラグインが新しい設定を受け入れた場合、$EMQX_DATA_DIR/plugins/my_emqx_plugin/config.hoconに永続化されます。

TIP

on_config_changed/2コールバック関数はアプリケーションが起動していなくても呼び出されます。

TIP

on_config_changed/2コールバック関数はEMQXクラスターの各ノードで呼び出されます。ローカルシステムの状態(例:ネットワークの可用性チェック)に依存した設定検証は避けてください。ノード間で結果が不整合になる可能性があります。代わりにon_health_check/1を使用してランタイムチェックを行い、リソースが利用できない場合は不健康状態を報告してください。

起動

プラグインはDashboard、API、CLIから手動で起動します。起動時には:

  • プラグインのアプリケーションが起動されます。
  • プラグインはEMQX設定のplugins.statesenabledとして登録されます。

プラグインが起動している状態で情報が要求されると、on_health_check/1コールバック関数が呼び出され、プラグインの状態が取得されます。

停止

プラグインを停止すると:

  • プラグインのアプリケーションが停止されます。
  • プラグインはEMQX設定のplugins.statesdisabledとして登録されます。

プラグインのアプリケーションは停止されますが、コードはノード上に残ります。停止中のプラグインも設定は可能です。

アンインストール手順

アンインストールの流れは以下の通りです。

  1. プラグインを停止します(起動中の場合)。
  2. プラグインのコードをノードからアンロードします。
  3. パッケージファイルをノードから削除します(設定ファイルは保持されます)。
  4. プラグインはEMQX設定のplugins.statesから登録解除されます。

プラグインのアンインストールはDashboardまたはCLIから行えます。詳細はプラグインのインストールと管理を参照してください。

クラスター参加時の挙動

EMQXノードがクラスターに参加する際、プラグインや設定は各ノードのローカルファイルシステムに存在するため、実際にはインストール・設定されていない場合があります。

新規ノードは以下の処理を行います:

  • クラスター参加プロセスの一環としてグローバルなEMQX設定を取得します。
  • EMQX設定からプラグインの状態(どのプラグインがインストールされ、どれが有効か)を把握します。
  • 他のノードからプラグインとその実際の設定を要求します。
  • プラグインをインストールし、有効なものは起動します。

プラグインのインストールと管理

EMQXはDashboard、CLI、APIを通じてプラグインパッケージのインストール、アンインストール、管理をサポートしています。

Dashboardからのパッケージインストール

プラグインがすでにビルドされ、my_emqx_plugin-1.0.0.tar.gzのtarballが用意されているとします。Dashboardから直接コンパイル済みプラグインパッケージをインストールする手順は以下の通りです。

重要なセキュリティアップデート

セキュリティ上の理由から、EMQXはDashboard経由でのプラグインインストールに対して明示的な許可を要求するようになりました。

  • インストール開始前に許可を与える必要があります。
  • 許可状態は一時的で、インストール完了後に自動的に取り消されます。
  • クラスター環境では、インストール前に全ノードで許可を与える必要があります。
  1. CLIで以下のコマンドを実行し、プラグインインストールを明示的に許可します。

    bash
    emqx ctl plugins allow $NAME-$VSN
    • {NAME}:プラグイン名(例:my_emqx_plugin
    • {VSN}:プラグインのバージョン(例:1.0.0

    このコマンド実行後、Dashboardからインストールを進められます。

  2. EMQX Dashboardの Management -> Plugins に移動します。

  3. + Install plugin ボタンをクリックしてインストールページを開きます。

  4. プラグインパッケージを選択またはドラッグしてDashboardにアップロードします。

    plugin-list-empty

  5. Install ボタンをクリックしてインストールを完了します。プラグイン一覧に新しいプラグインが表示されます。

    plugin-list-installed

これでプラグインの起動・停止や設定が可能になります。Dashboardからプラグインをアンインストールするには、プラグイン一覧ページのActions列のMoreメニューからUninstallボタンをクリックしてください。

以前に許可したプラグインの許可を取り消すには、以下のいずれかを行います。

  1. プラグインをアンインストールする(すでにインストール済みの場合)。
  2. 以下のコマンドで明示的に許可を取り消す。
bash
emqx ctl plugins disallow $NAME-$VSN

CLIからのパッケージインストール

プラグインがすでにビルドされ、my_emqx_plugin-1.0.0.tar.gzのtarballが用意されているとします。CLIから直接コンパイル済みプラグインパッケージをインストールする手順は以下の通りです。

  1. EMQXノード上でtarballをEMQXプラグインディレクトリにコピーします。

    $ cp my_emqx_plugin-1.0.0.tar.gz $EMQX_HOME/plugins
  2. プラグインをインストールします。

    $ emqx ctl plugins install my_emqx_plugin-1.0.0
  3. プラグイン一覧を確認します。

    $ emqx ctl plugins list
  4. プラグインを起動・停止します。

    $ emqx ctl plugins start my_emqx_plugin-1.0.0
    $ emqx ctl plugins stop my_emqx_plugin-1.0.0
  5. プラグインをアンインストールします。

    $ emqx ctl plugins uninstall my_emqx_plugin-1.0.0

APIからのパッケージインストール

プラグインがすでにビルドされ、my_emqx_plugin-1.0.0.tar.gzのtarballが用意されているとします。APIを使ってプラグインをインストールする手順は以下の通りです。

  1. インストールを許可します。以下のコマンドを実行してプラグインのインストールを有効にします。

    emqx ctl plugins allow my_emqx_plugin-1.0.0
  2. curlを使ってPOSTリクエストを送り、プラグインをインストールします。

    $ curl -u $KEY:$SECRET -X POST http://$EMQX_HOST:18083/api/v5/plugins/install -H "Content-Type: multipart/form-data" -F "plugin=@my_emqx_plugin-1.0.0.tar.gz"
  3. プラグイン一覧を確認して、インストールが成功したかを検証します。

    $ curl -u $KEY:$SECRET http://$EMQX_HOST:18083/api/v5/plugins | jq
  4. プラグインを起動・停止します。

    $ curl -s -u $KEY:$SECRET -X PUT "http://$EMQX_HOST:18083/api/v5/plugins/my_emqx_plugin-1.0.0/start"
    $ curl -s -u $KEY:$SECRET -X PUT "http://$EMQX_HOST:18083/api/v5/plugins/my_emqx_plugin-1.0.0/stop"

プラグインのアップグレード

EMQXでは同一プラグインの複数バージョンを同時にインストールすることはできません。

新しいバージョンをインストールするには:

  • まず古いバージョンをアンインストールします。
  • その後、新しいバージョンをインストールします。

プラグインの設定はインストール間で保持されます。