桥接数据到 RocketMQ

搭建 RocketMQ 环境,以 MacOS X ​ 为例:

  1. $ wget https://mirrors.bfsu.edu.cn/apache/rocketmq/4.8.0/rocketmq-all-4.8.0-bin-release.zip
  2. $ unzip rocketmq-all-4.8.0-bin-release.zip
  3. $ cd rocketmq-all-4.8.0-bin-release/
  4. # 在conf/broker.conf添加了2个配置
  5. brokerIP1 = 127.0.0.1
  6. autoCreateTopicEnable = true
  7. # 启动 RocketMQ NameServer
  8. $ ./bin/mqnamesrv
  9. # 启动 RocketMQ Broker
  10. $ ./bin/mqbroker -n localhost:9876 -c conf/broker.conf

创建规则:

打开 EMQX DashboardBridge data to RocketMQ - 图1 (opens new window),选择左侧的 “规则” 选项卡。

填写规则 SQL:

  1. SELECT * FROM "t/#"

image

关联动作:

在 “响应动作” 界面选择 “添加”,然后在 “动作” 下拉框里选择 “桥接数据到 RocketMQ”。

image

填写动作参数:

“保存数据到 RocketMQ 动作需要两个参数:

1). RocketMQ 的消息主题

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

image

按照 RocketMQ ACL 的配置填写。 ACL 信息请咨询服务提供商,本地或私有部署,可以在配置文件中查看,配置文件路径需要按照部署方式的不同改变前缀。

  1. ${rocket_path}/conf/plain_acl.yml

填写资源配置:

填写真实的 RocketMQ 服务器地址,多个地址用,分隔,其他配置保持默认值,然后点击 “测试连接” 按钮,确保连接测试成功。

最后点击 “新建” 按钮。

image

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

image

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

image

规则已经创建完成,现在发一条数据:

  1. Topic: "t/1"
  2. QoS: 0
  3. Payload: "hello"

然后通过 RocketMQ 命令去查看消息是否生产成功:

  1. $ ./bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer TopicTest

image

在规则列表里,可以看到刚才创建的规则的命中次数已经增加了 1:

image