Skip to content

Redisとの統合

EMQXはパスワード認証のためにRedisとの統合をサポートしています。EMQXのRedis認証機能は、現在、Single、Redis Sentinel、およびRedis Clusterの3つの異なるモードで動作するRedisへの接続をサポートしています。本セクションでは、サポートされるデータスキーマの詳細と、EMQXダッシュボードおよび設定ファイルでの設定方法について説明します。

前提条件:

基本的なEMQX認証の概念の知識

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

Redis認証は、あらかじめ定義されたフィールド名を持つRedisハッシュに格納された認証情報を使用します。

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

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

bash
>redis-cli
127.0.0.1:6379> HSET mqtt:user123 is_superuser 1 salt salt password_hash ac63a624e7074776d677dd61a003b8c803eb11db004d0ec6ae032a5d7c9c5caf
(integer) 3

対応する設定パラメータは以下の通りです。

password_hash_algorithm {
    name = sha256
    salt_position = prefix
}

cmd = "HMGET mqtt:${username} password_hash salt is_superuser"

TIP

password_hash という名前はハッシュ化されたパスワードを保存することを示しています。しかし、RedisにはMySQLのような as 構文がないため、EMQX 5.0ではEMQX 4.xの互換性を保つために password フィールドもサポートしています。

そのため、cmdHMGET mqtt:${username} password salt is_superuser と設定することも可能です。

ダッシュボードでの設定

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

  1. EMQXダッシュボードの左側ナビゲーションメニューから アクセス制御 -> 認証 をクリックします。
  2. 認証 ページの右上にある 作成 をクリックします。
  3. メカニズムパスワードベース を、バックエンドRedis を選択し、設定 タブに進みます。以下のように表示されます。
Redisによる認証

認証の設定方法は以下の通りです。

接続:Redisへの接続情報を入力します。

  • Redisモード:Redisの展開方法を選択します。SingleSentinelCluster のいずれかです。

  • サーバー:EMQXが接続するRedisサーバーのアドレスを指定します。RedisモードSentinel または Cluster の場合は、接続するすべてのRedisサーバーをカンマ(,)区切りで入力してください。

  • Sentinel名:使用する名前を指定します。文字列型で、RedisモードSentinel の場合にのみ必要です。

  • データベース:Redisのデータベース名。文字列型です。

  • ユーザー名:Redis接続に使用するユーザー名を指定します。このフィールドは、Redis 6.0で導入されたRedis ACLを使用している場合に必須です。Redisサーバーがデフォルトユーザー(ACLが無効または適用されていない)を使用している場合は空欄のままで構いません。

    TIP

    username フィールドはEMQX 5.2.0以降でサポートされています。Redis ACLを利用する場合は、EMQXのバージョンが5.2.0以上であることを確認してください。

  • パスワード:Redisユーザーのパスワードを指定します。認証が有効なRedisインスタンスに接続する場合は必須です。

    • ユーザー名を入力した場合、このパスワードはRedis ACL設定の認証情報と一致している必要があります。
    • ユーザー名が指定されていない場合、このパスワードは default ユーザーとして認証に使用されます(有効な場合)。

TLS設定:TLSを有効にする場合はトグルスイッチをオンにします。TLSの有効化についてはネットワークとTLSを参照してください。

接続設定:同時接続数を設定します。

  • プールサイズ(任意):EMQXノードからRedisサーバーへの同時接続数を指定します。デフォルトは 8 です。

認証設定:認証に関連する設定を行います。

  • パスワードハッシュ:プレーンテキストのパスワードに適用され、結果がデータベースに保存されるハッシュアルゴリズムを選択します。利用可能なオプションは plainmd5shasha256sha512bcryptpbkdf2 です。選択したアルゴリズムに応じて追加設定があります。
    • md5shasha256sha512 の場合:
      • ソルト位置:ソルト(ランダムデータ)をパスワードにどのように混ぜるかを指定します。suffix(後置)、prefix(前置)、disable(無効)のいずれかです。外部ストレージからユーザー認証情報をEMQX組み込みデータベースに移行しない限り、デフォルト値のままで問題ありません。
      • ハッシュ結果は16進数文字列で表され、大文字小文字を区別せずに保存された認証情報と比較されます。
    • plain の場合:
      • ソルト位置disable に設定してください。
    • bcrypt の場合:
      • ソルトラウンド:ハッシュ関数を適用する回数を定義します。2のべき乗で表される「コストファクター」です。デフォルトは 10、許容範囲は 5 から 10 です。セキュリティ強化のためには高い値が推奨されます。コストファクターを1増やすごとに認証に要する時間が倍増します。
    • pbkdf2 の場合:
      • 疑似乱数関数:鍵生成に使用するハッシュ関数を選択します(例:sha256)。
      • 反復回数:ハッシュ関数を実行する回数を設定します。デフォルトは 4096 です。
      • 派生鍵長(任意):生成される鍵の長さ(バイト単位)を指定します。空欄の場合は選択した疑似乱数関数に基づく長さが使用されます。
      • ハッシュ結果は16進数文字列で表され、大文字小文字を区別せずに保存された認証情報と比較されます。
  • CMD:Redisクエリコマンド。

設定が完了したら、作成 をクリックしてください。

設定項目での設定

EMQXの設定項目を使用してRedis認証機能を設定することも可能です。

TIP

EMQXは3種類のRedisインストール形態に対応しています。

::::