Skip to content

MongoDBとの統合

EMQXはパスワード認証のためにMongoDBとの統合をサポートしています。EMQXのMongoDB認証機能は現在、Single、レプリカセット、およびシャーディングの3つの異なるモードで稼働するMongoDBへの接続をサポートしています。本ページでは、サポートされているデータスキーマの詳細と、EMQXダッシュボードおよび設定ファイルでの設定方法について説明します。

TIP

基本的なEMQX認証の概念の知識を推奨します。

データスキーマとクエリ文

EMQXのMongoDB認証機能は、認証データをMongoDBドキュメントとして保存することをサポートしています。ユーザーはクエリ文のテンプレートを提供し、以下のフィールドが含まれていることを確認する必要があります。

  • password_hash:必須。データベースに保存されるパスワード(プレーンテキストまたはハッシュ済み)。このフィールドは名前変更が可能です。
  • salt:任意。salt = "" またはこのフィールドを削除すると、ソルト値が追加されないことを示します。このフィールドは名前変更が可能です。
  • is_superuser:任意。現在のクライアントがスーパーユーザーかどうかのフラグ。デフォルトは false。このフィールドは名前変更が可能です。

例えば、ユーザー名が user123、パスワードが secret、サフィックスとして salt_foo123 のソルトを付与し、パスワードハッシュが sha256 のスーパーユーザー(is_superuser: true)のドキュメントを追加したい場合、クエリ文は以下のようになります。

> db.mqtt_user.insertOne(
  {
      "username": "emqx_u",
      "salt": "slat_foo123",
      "is_superuser": true,
      "password_hash": "44edc2d57cde8d79c98145003e105b90a14f1460b79186ea9cfe83942fc5abb5"
  }
);
{
  "acknowledged" : true,
  "insertedId" : ObjectId("631989e20a33e26b05b15abe")
}

TIP

システム内のユーザー数が多い場合は、クエリ応答時間を短縮しEMQXの負荷を軽減するために、事前にテーブルの最適化およびインデックスの設定を行ってください。

このMongoDBデータスキーマに対応するダッシュボードの設定パラメータは以下の通りです:

  • Password Hashsha256
  • Salt Positionsuffix
  • Collectionmqtt_user
  • Filter{ username = "${username}" }
  • Password Hash fieldpassword_hash
  • Salt Fieldsalt
  • is_superuser Fieldis_superuser

ダッシュボードでの設定

EMQXダッシュボードを使ってMongoDBをパスワード認証に利用する設定が可能です。

  1. EMQXダッシュボードの左側ナビゲーションメニューから Access Control -> Authentication をクリックします。
  2. Authentication ページの右上にある Create をクリックします。
  3. MechanismPassword-Based を選択し、BackendMongoDB を選択すると、以下のように Configuration タブに移動します。

authn-MongoDB_ee

  1. 以下の手順に従い認証バックエンドの設定を行います:

    • MongoDBへの接続情報を入力します:

      • MongoDB Mode:MongoDBの展開形態を選択します。SingleReplica SetSharding のいずれかです。
      • Server:EMQXが接続するMongoDBサーバーのアドレスを指定します。MongoDB ModeReplica Set または Sharding の場合は、接続するすべてのMongoDBサーバーをカンマ(,)で区切って入力してください。
      • Replica Set Name:使用するレプリカセット名を指定します。文字列型で、MongoDB ModeReplica Set の場合のみ必要です。
      • Database:MongoDBのデータベース名。文字列型です。
      • Collection:認証ルールが保存されているMongoDBコレクション名。文字列型です。
      • Username:MongoDBのユーザー名を指定します。
      • Password:MongoDBのユーザーパスワードを指定します。
      • Read Mode(任意):MongoDB ModeReplica Set の場合のみ必要です。デフォルトは master。選択肢は masterslave_ok です。
        • master:クエリはすべて最新のデータ(マスター/プライマリサーバー)からのみ読み取ります。接続先がマスターでない場合、最初の読み取りは失敗し、その後の操作は中止されます。
        • slave_ok:クエリはセカンダリ/スレーブサーバーからの古いデータまたはマスターからの最新データを読み取ることができます。
      • Write Mode(任意):MongoDB ModeReplica Set の場合のみ必要です。選択肢は unsafesafe で、デフォルトは safe です。
    • 認証に関する設定を行います:

      • Password Hash Field:パスワードのフィールド名を指定します。
      • Password Hash:プレーンテキストのパスワードに適用され、データベースに保存される前のハッシュアルゴリズムを選択します。利用可能なオプションは plainmd5shasha256sha512bcryptpbkdf2 です。選択したアルゴリズムに応じて追加設定が必要です。
        • md5shasha256sha512 の場合:
          • Salt Position:ソルト(ランダムデータ)をパスワードにどのように混ぜるかを指定します。suffixprefixdisable のいずれかです。外部ストレージからユーザー認証情報を移行する場合を除き、デフォルト値のままで問題ありません。
          • ハッシュ結果は16進数文字列で表され、大文字小文字を区別せずに保存された認証情報と比較されます。
        • plain の場合:
          • Salt Positiondisable に設定してください。
        • bcrypt の場合:
          • Salt Rounds:ハッシュ関数の適用回数を定義します。2のべき乗(2^Salt Rounds)で表され、「コストファクター」とも呼ばれます。デフォルトは 10、許容範囲は 5 から 10 です。セキュリティ強化のためにはより高い値を推奨します。注:コストファクターを1増やすごとに認証に必要な時間が倍増します。
        • pbkdf2 の場合:
          • Pseudorandom Function:キー生成に用いるハッシュ関数を選択します(例:sha256)。
          • Iteration Count:ハッシュ関数の実行回数を設定します。デフォルトは 4096 です。
          • Derived Key Length(任意):生成されるキーのバイト長を指定します。空欄の場合は選択された擬似乱数関数に基づく長さになります。
          • ハッシュ結果は16進数文字列で表され、大文字小文字を区別せずに保存された認証情報と比較されます。
      • Salt Field:MongoDBのソルトフィールドを指定します。
      • is_superuser Field:ユーザーがスーパーユーザーかどうかを判定するフィールドを指定します。
      • Client ID Override Field:MongoDB認証結果のフィールド名を指定し、接続時にクライアントが提供したClient IDを上書き可能にします。これにより認証データに基づいて一意のClient IDを割り当て、多重テナントなどのシナリオでセッション競合を防止できます。
      • PreconditionVariform式を用いて、このMongoDB認証機能をクライアント接続に適用するかどうかを制御します。この式はクライアントの属性(usernameclientidlistenerなど)に対して評価され、結果が文字列 "true" の場合のみ認証機能が呼び出されます。それ以外の場合はスキップされます。詳細はAuthenticator Preconditionsを参照してください。
      • Enable TLS:TLSを有効にする場合はトグルスイッチをオンにします。TLS有効化の詳細はNetwork and TLSを参照してください。
      • Filter:MongoDBのセレクターとして解釈されるマップ。認証プレースホルダーがサポートされています。
      • Advanced Settings:同時接続数と接続タイムアウトまでの待機時間を設定します。
        • Connection Pool size(任意):EMQXノードからMongoDBサーバーへの同時接続数を指定します。デフォルトは 8 です。
        • Connect Timeout(任意):接続がタイムアウトと見なされるまでの待機時間を指定します。単位はミリ秒、秒、分、時間に対応。デフォルトは 20 秒です。
  2. 設定が完了したら、Create をクリックしてください。

設定項目による設定

EMQXのMongoDB認証機能は設定ファイルでも設定可能です。

以下は参考となるコード例です: