MQTT

WeEvent服务支持MQTT Broker功能。任何支持MQTT协议的IoT设备及客户端都能连接到WeEvent,并进行消息发布及订阅。

协议介绍

  • MQTT是物联网IoT中的主流接入协议,协议具体内容参见http://mqtt.org/
  • WeEvent支持MQTT 3.1.1

配置MQTT服务

Broker服务中,修改配置文件./conf/weevent.properties,然后重新启动服务。

#mqtt brokerserver
mqtt.broker.port=7001
mqtt.broker.keepalive=60
mqtt.websocket.path=/weevent-broker/mqtt

参数说明:

  • mqtt.broker.port

    客户端使用WebSocket协议访问MQTT Broker

  • mqtt.broker.keepalive

    发送心跳时间。单位为秒。

  • mqtt.websocket.path

    客户端使用WebSocket协议访问MQTT Broker链接。

注意事项

  • 区块链必须确保消息成功上链,暂不支持QoS-0和QoS-2消息级别。
  • 不支持断连后会话恢复功能。

样例演示

样例演示需依赖Mosquitto客户端,请根据链接(https://mosquitto.org/download/)进行下载安装。更多客户端参见MQTT第三方库

  • IoT设备发布事件

    发送消息前需创建topic (com.weevent.test)。详情请参照创建Topic

    $ mosquitto_pub -h localhost -p 7000 -q 1 -t "com.weevent.test" -m "{\"timestamp\":133345566,\"key\":\"temperature\",\"value\":10.0}"
    
  • IoT设备订阅事件

    $ mosquitto_sub -h localhost -p 7000 -q 1 -t "com.weevent.test"
    {"eventId":"317e7c4c-1-24","extensions":{},"topic":"com.weevent.test","content":[123,34,116,105,109,101,115,116,97,109,112,34,58,49,51,51,51,52,53,53,54,54,44,34,107,101,121,34,58,34,116,101,109,112,101,114,97,116,117,114,101,34,44,34,118,97,108,117,101,34,58,49,48,46,48,125]}