PostgreSQLとの連携
このオーソライザーは、PostgreSQLデータベースに格納されたルールリストとパブリッシュ/サブスクリプション要求を照合することで認可チェックを実装しています。
前提条件
EMQX認可の基本概念についての知識
データスキーマとクエリ文
PostgreSQLオーソライザーはほぼあらゆるストレージスキーマをサポートしています。ACLルールの保存方法やアクセス方法は、ユーザーが単一または複数のテーブルやビューなどを用いて自由に決定できます。
ユーザーはクエリ文のテンプレートを提供し、以下のフィールドが含まれていることを保証する必要があります。
permissionはルールがマッチした場合に適用されるアクションを指定します。denyまたはallowのいずれかである必要があります。actionはルールが関連するリクエストを指定します。publish、subscribe、またはallのいずれかである必要があります。topicはルールに関連するトピックのフィルターを指定します。ワイルドカードやトピックプレースホルダーをサポートする文字列である必要があります。qos(省略可能)はルールが適用されるQoSレベルを指定します。0、1、2のいずれか、またはカンマ区切りで複数指定可能(例:0,1)。デフォルトはすべてのQoSレベルです。retain(省略可能)は現在のルールがリテインドメッセージをサポートするかどうかを指定します。値は0または1。デフォルトはリテインドメッセージを許可します。
認証情報を格納するテーブルの例:
CREATE TABLE mqtt_acl(
id serial PRIMARY KEY,
username text NOT NULL,
permission text NOT NULL,
action text NOT NULL,
topic text NOT NULL,
qos smallint,
retain smallint
);
CREATE INDEX mqtt_acl_username_idx ON mqtt_acl(username);このテーブルでは、MQTTユーザーは username で識別されます。
例えば、ユーザー user123 に対してトピック data/user123/# のパブリッシュを許可する認可ルールを追加したい場合、クエリ文は以下のようになります。
postgres=# INSERT INTO mqtt_acl(username, permission, action, topic, ipaddress) VALUES ('user123', 'allow', 'publish', 'data/user123/#', '127.0.0.1');
INSERT 0 1対応する設定パラメータは以下の通りです。
query = "SELECT permission, action, topic, ipaddress, qos, retain FROM mqtt_acl WHERE username = ${username} and ipaddress = ${peerhost}"ダッシュボードでの設定
EMQXダッシュボードを使って、PostgreSQLをユーザー認可に利用する設定が可能です。
EMQXダッシュボードの左側ナビゲーションツリーで アクセス制御 -> 認可 をクリックし、認可 ページに入ります。
右上の 作成 をクリックし、バックエンド に PostgreSQL を選択して 次へ をクリックします。以下のように 設定 タブが表示されます。

以下の指示に従い認可バックエンドを設定します。
PostgreSQLへの接続情報を入力します。
- サーバー:EMQXが接続するサーバーアドレス(
host:port)を指定します。 - データベース:PostgreSQLのデータベース名。
- ユーザー名:ユーザー名を指定します。
- パスワード:ユーザーパスワードを指定します。
- サーバー:EMQXが接続するサーバーアドレス(
TLSを有効にする:TLSを有効にする場合はトグルスイッチをオンにします。TLS有効化の詳細はネットワークとTLSを参照してください。
SQL:データスキーマに応じてクエリ文を入力します。詳細はデータスキーマとクエリ文を参照してください。
詳細設定:接続プール、タイムアウト、プリペアドステートメントの動作を設定します。
- 接続プールサイズ(省略可能):EMQXノードからPostgreSQLへの同時接続数を整数で指定します。デフォルトは
8。 - 接続タイムアウト(省略可能):接続試行がタイムアウトとみなされるまでの待機時間を指定します。ミリ秒、秒、分、時間単位が利用可能です。デフォルトは
15秒。 - プリペアドステートメントを無効化(省略可能):データベースクエリでプリペアドステートメントの利用を無効にします。PostgreSQLのプロキシやミドルウェア(例:PGBouncerやSupabaseのトランザクションモード)がセッションレベルの機能(プリペアドステートメントなど)をサポートしない場合に有効にしてください。デフォルトは無効。
- 接続プールサイズ(省略可能):EMQXノードからPostgreSQLへの同時接続数を整数で指定します。デフォルトは
作成 をクリックして設定を完了します。
設定項目による設定
EMQXの設定項目を使ってPostgreSQLオーソライザーを設定することも可能です。
PostgreSQLオーソライザーは postgresql タイプで識別されます。設定パラメータの全リストはEMQX Enterprise設定マニュアルを参照してください。
設定例:
{
type = postgresql
database = "mqtt"
username = "postgres"
password = "public"
server = "127.0.0.1:5432"
query = "SELECT permission, action, topic FROM mqtt_acl WHERE username = ${username}"
connect_timeout = "15s"
disable_prepared_statements = false
}