从 MySQL 中获取订阅关系

搭建 MySQL 数据库,并设置用户名密码为 root/public,以 MacOS X 为例:

  1. $ brew install mysql
  2. $ brew services start mysql
  3. $ mysql -u root -h localhost -p
  4. ALTER USER 'root'@'localhost' IDENTIFIED BY 'public';

初始化 MySQL 数据库:

  1. $ mysql -u root -h localhost -ppublic
  2. create database mqtt;

创建 mqtt_sub 表:

  1. DROP TABLE IF EXISTS `mqtt_sub`;
  2. CREATE TABLE `mqtt_sub` (
  3. `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  4. `clientid` varchar(64) DEFAULT NULL,
  5. `topic` varchar(180) DEFAULT NULL,
  6. `qos` tinyint(1) DEFAULT NULL,
  7. PRIMARY KEY (`id`),
  8. KEY `mqtt_sub_idx` (`clientid`,`topic`,`qos`),
  9. UNIQUE KEY `mqtt_sub_key` (`clientid`,`topic`),
  10. INDEX topic_index(`id`, `topic`)
  11. ) ENGINE=InnoDB DEFAULT CHARSET=utf8MB4;

WARNING

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

创建规则:

打开 EMQ X Dashboard从 MySQL 中获取订阅关系 - 图1 (opens new window),选择左侧的“规则”选项卡。

然后填写规则 SQL:

  1. SELECT * FROM "$events/client_connected"

从 MySQL 中获取订阅关系 - 图2

关联动作:

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

从 MySQL 中获取订阅关系 - 图3

填写动作参数:

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

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

从 MySQL 中获取订阅关系 - 图4

弹出“创建资源”对话框

从 MySQL 中获取订阅关系 - 图5

填写资源配置:

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

最后点击 “确定” 按钮。

从 MySQL 中获取订阅关系 - 图6

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

从 MySQL 中获取订阅关系 - 图7

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

从 MySQL 中获取订阅关系 - 图8

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

  1. insert into mqtt_sub(clientid, topic, qos) values("test", "t1", 1);

从 MySQL 中获取订阅关系 - 图9

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

从 MySQL 中获取订阅关系 - 图10

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

从 MySQL 中获取订阅关系 - 图11