代码拉取完成,页面将自动刷新
使用开源reactor-netty库,实现MQTT server。集成了springboot autoconfig实现快速注入容器。 框架采用反应式reactor3库,是代码具有低延迟,高吞吐量等特点。
RsocketServerSession serverSession=TransportServer.create("192.168.100.237",1884)
.auth((s,p)->true)
.heart(100000)
.protocol(ProtocolType.MQTT)
.ssl(false)
.auth((username,password)->true)
.log(true)
.messageHandler(new MemoryMessageHandler())
.exception(throwable -> System.out.println("&&&&&&&&&&&&&&&&&&&&&&&&&&&&"+throwable))
.start()
.block();
serverSession.closeConnect("device-1").subscribe();// 关闭设备端
List<TransportConnection> connections= serverSession.getConnections().block(); // 获取所有链接
RsocketClientSession clientSession= TransportClient.create("127.0.0.1",1884)
.heart(10000)
.protocol(ProtocolType.MQTT) // 指定协议 MQTT 包含 TCP/WS 两个端口 默认WS走的8443 WS协议 仅仅启动TCP协议
.ssl(false) // 开发tls加密
.log(true) // 打印报文日志
.onClose(()->{}) // 客户端关闭事件
.clientId("Comsumer_3") // 客户端id
.password("12") // 密码
.username("123") // 用户名
.willMessage("123") // 遗嘱消息
.willTopic("/lose") // 遗嘱消息topic
.willQos(MqttQoS.AT_LEAST_ONCE) // 遗嘱消息qos
.exception(throwable -> System.out.println("&&&&&&&&&&&&&&&&&&&&&&&&&&&&"+throwable)) // 异常处理
.messageAcceptor((topic,msg)->{
System.out.println(topic+":"+new String(msg));
}) // 消息接收处理
.connect()
.block();
clientSession.sub("test").subscribe(); // 订阅
clientSession.pub("test","Producer_3".getBytes()).subscribe(); // 发布qos0消息
clientSession.pub("test","Producer_1".getBytes(),1).subscribe(); // 发布qos1消息
clientSession.pub("test","Producer_1".getBytes(),true,1).subscribe(); // 发布qos1消息 保留消息
yaml 配置:
iot:
mqtt:
server:
enable: true
host: 192.168.100.237
port: 8081
log: false
protocol: MQTT
heart: 100000
ssl: false
设备校验:实现AuthencationSession接口注入容器即可
异常处理:实现ExceptorAcceptor接口注入容器即可
保留消息处理:实现RsocketMessageHandler接口注入容器即可,默认使用内存。
qq群号: 789331252
物联网
扫码加入微信交流群此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。
代码活跃度
社区活跃度
团队健康
流行趋势
影响力
:与代码提交频次相关
:与项目和用户的issue、pr互动相关
:与团队成员人数和稳定度相关
:与项目近期受关注度相关
:与项目的star、下载量等社交指标相关