从 PostgreSQL 中获取订阅关系

EMQX 客服发表于:2022年05月11日 10:27:04

从 PostgreSQL 中获取订阅关系

搭建 PostgreSQL 数据库,以 MacOS X 为例:

$ brew install postgresql
$ brew services start postgresql

创建 mqtt 数据库:

# 使用用户名 postgres 创建名为 'mqtt' 的数据库
$ createdb -U postgres mqtt

$ psql -U postgres mqtt

mqtt=> \dn;
List of schemas
Name  | Owner
--------+-------
public | postgres
(1 row)

创建 mqtt_sub 表:

$ psql -U postgres mqtt
CREATE TABLE mqtt_sub(
  id SERIAL8 primary key,
  clientid character varying(64),
  topic character varying(255),
  qos integer,
  UNIQUE (clientid, topic)
);

注:订阅关系表结构不能修改,请使用上面SQL语句创建

创建规则:

打开 EMQX Dashboard,选择左侧的“规则”选项卡。

然后填写规则 SQL:

SELECT * FROM "$events/client_connected"

image.png

关联动作:

在“响应动作”界面选择“添加动作”,然后在“新增动作”下拉框里选择“从PostgreSQL中获取订阅列表”

image.png

填写动作参数:

“从PostgreSQL中获取订阅列表“ 动作需要一个参数:

1). 关联资源。现在资源下拉框为空,可以点击右上角的 “新建” 来创建一个 PostgreSQL 资源:

image.png

弹出“创建资源”对话框

image.png

填写资源配置:

  填写真实的 PostgreSQL 服务器地址,其他配置相应的值,然后点击 “测试连接” 按钮,确保连接测试成功。

最后点击 “确定” 按钮。

image.png

返回响应动作界面,点击 “确认”。

image.png

返回规则创建界面,点击 “创建”。

image.png

规则已经创建完成,通过 “psql” 往PostgreSQL插入一条订阅关系

insert into mqtt_sub(clientid, topic, qos) values('pgsql', 'testTopic', 1)

image.png

通过 Dashboard 登录 clientid 为 pgsql 的设备:

image.png

查看“订阅”列表,可以看到 Broker 从 PostgreSQL 里面获取到订阅关系,并代理设备订阅:

image.png


    您需要登录后才可以回复