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 Hash:
sha256 - Salt Position:
suffix - Collection:
mqtt_user - Filter:
{ username = "${username}" } - Password Hash field:
password_hash - Salt Field:
salt - is_superuser Field:
is_superuser
ダッシュボードでの設定
EMQXダッシュボードを使ってMongoDBをパスワード認証に利用する設定が可能です。
- EMQXダッシュボードの左側ナビゲーションメニューから Access Control -> Authentication をクリックします。
- Authentication ページの右上にある Create をクリックします。
- Mechanism に Password-Based を選択し、Backend に MongoDB を選択すると、以下のように Configuration タブに移動します。

以下の手順に従い認証バックエンドの設定を行います:
MongoDBへの接続情報を入力します:
- MongoDB Mode:MongoDBの展開形態を選択します。
Single、Replica Set、Shardingのいずれかです。 - Server:EMQXが接続するMongoDBサーバーのアドレスを指定します。MongoDB Mode が
Replica SetまたはShardingの場合は、接続するすべてのMongoDBサーバーをカンマ(,)で区切って入力してください。 - Replica Set Name:使用するレプリカセット名を指定します。文字列型で、MongoDB Mode が
Replica Setの場合のみ必要です。 - Database:MongoDBのデータベース名。文字列型です。
- Collection:認証ルールが保存されているMongoDBコレクション名。文字列型です。
- Username:MongoDBのユーザー名を指定します。
- Password:MongoDBのユーザーパスワードを指定します。
- Read Mode(任意):MongoDB Mode が
Replica Setの場合のみ必要です。デフォルトはmaster。選択肢はmaster、slave_okです。- master:クエリはすべて最新のデータ(マスター/プライマリサーバー)からのみ読み取ります。接続先がマスターでない場合、最初の読み取りは失敗し、その後の操作は中止されます。
- slave_ok:クエリはセカンダリ/スレーブサーバーからの古いデータまたはマスターからの最新データを読み取ることができます。
- Write Mode(任意):MongoDB Mode が
Replica Setの場合のみ必要です。選択肢はunsafe、safeで、デフォルトはsafeです。
- MongoDB Mode:MongoDBの展開形態を選択します。
認証に関する設定を行います:
- Password Hash Field:パスワードのフィールド名を指定します。
- Password Hash:プレーンテキストのパスワードに適用され、データベースに保存される前のハッシュアルゴリズムを選択します。利用可能なオプションは
plain、md5、sha、sha256、sha512、bcrypt、pbkdf2です。選択したアルゴリズムに応じて追加設定が必要です。md5、sha、sha256、sha512の場合:- Salt Position:ソルト(ランダムデータ)をパスワードにどのように混ぜるかを指定します。
suffix、prefix、disableのいずれかです。外部ストレージからユーザー認証情報を移行する場合を除き、デフォルト値のままで問題ありません。 - ハッシュ結果は16進数文字列で表され、大文字小文字を区別せずに保存された認証情報と比較されます。
- Salt Position:ソルト(ランダムデータ)をパスワードにどのように混ぜるかを指定します。
plainの場合:- Salt Position は
disableに設定してください。
- Salt Position は
bcryptの場合:- Salt Rounds:ハッシュ関数の適用回数を定義します。2のべき乗(2^Salt Rounds)で表され、「コストファクター」とも呼ばれます。デフォルトは
10、許容範囲は5から10です。セキュリティ強化のためにはより高い値を推奨します。注:コストファクターを1増やすごとに認証に必要な時間が倍増します。
- Salt Rounds:ハッシュ関数の適用回数を定義します。2のべき乗(2^Salt Rounds)で表され、「コストファクター」とも呼ばれます。デフォルトは
pbkdf2の場合:- Pseudorandom Function:キー生成に用いるハッシュ関数を選択します(例:
sha256)。 - Iteration Count:ハッシュ関数の実行回数を設定します。デフォルトは
4096です。 - Derived Key Length(任意):生成されるキーのバイト長を指定します。空欄の場合は選択された擬似乱数関数に基づく長さになります。
- ハッシュ結果は16進数文字列で表され、大文字小文字を区別せずに保存された認証情報と比較されます。
- Pseudorandom Function:キー生成に用いるハッシュ関数を選択します(例:
- Salt Field:MongoDBのソルトフィールドを指定します。
- is_superuser Field:ユーザーがスーパーユーザーかどうかを判定するフィールドを指定します。
- Client ID Override Field:MongoDB認証結果のフィールド名を指定し、接続時にクライアントが提供したClient IDを上書き可能にします。これにより認証データに基づいて一意のClient IDを割り当て、多重テナントなどのシナリオでセッション競合を防止できます。
- Precondition:Variform式を用いて、このMongoDB認証機能をクライアント接続に適用するかどうかを制御します。この式はクライアントの属性(
username、clientid、listenerなど)に対して評価され、結果が文字列"true"の場合のみ認証機能が呼び出されます。それ以外の場合はスキップされます。詳細はAuthenticator Preconditionsを参照してください。 - Enable TLS:TLSを有効にする場合はトグルスイッチをオンにします。TLS有効化の詳細はNetwork and TLSを参照してください。
- Filter:MongoDBのセレクターとして解釈されるマップ。認証プレースホルダーがサポートされています。
- Advanced Settings:同時接続数と接続タイムアウトまでの待機時間を設定します。
- Connection Pool size(任意):EMQXノードからMongoDBサーバーへの同時接続数を指定します。デフォルトは
8です。 - Connect Timeout(任意):接続がタイムアウトと見なされるまでの待機時間を指定します。単位はミリ秒、秒、分、時間に対応。デフォルトは
20秒です。
- Connection Pool size(任意):EMQXノードからMongoDBサーバーへの同時接続数を指定します。デフォルトは
設定が完了したら、Create をクリックしてください。
設定項目による設定
EMQXのMongoDB認証機能は設定ファイルでも設定可能です。
以下は参考となるコード例です: