Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
mica
mica-mqtt
提交
6fb20678
mica-mqtt
项目概览
mica
/
mica-mqtt
通知
71
Star
1
Fork
1
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
mica-mqtt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
6fb20678
编写于
12月 25, 2021
作者:
浅梦2013
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
✨
mica-mqtt client 重复订阅优化。
上级
622031c4
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
20 addition
and
13 deletion
+20
-13
mica-mqtt-core/src/main/java/net/dreamlu/iot/mqtt/core/client/DefaultMqttClientSession.java
...reamlu/iot/mqtt/core/client/DefaultMqttClientSession.java
+7
-0
mica-mqtt-core/src/main/java/net/dreamlu/iot/mqtt/core/client/MqttClient.java
...ain/java/net/dreamlu/iot/mqtt/core/client/MqttClient.java
+13
-13
未找到文件。
mica-mqtt-core/src/main/java/net/dreamlu/iot/mqtt/core/client/DefaultMqttClientSession.java
浏览文件 @
6fb20678
...
...
@@ -20,6 +20,8 @@ import net.dreamlu.iot.mqtt.codec.MqttQoS;
import
net.dreamlu.iot.mqtt.core.common.MqttPendingPublish
;
import
net.dreamlu.iot.mqtt.core.common.MqttPendingQos2Publish
;
import
net.dreamlu.iot.mqtt.core.util.MultiValueMap
;
import
org.slf4j.Logger
;
import
org.slf4j.LoggerFactory
;
import
java.util.*
;
...
...
@@ -29,6 +31,7 @@ import java.util.*;
* @author L.cm
*/
public
final
class
DefaultMqttClientSession
implements
IMqttClientSession
{
private
static
final
Logger
logger
=
LoggerFactory
.
getLogger
(
DefaultMqttClientSession
.
class
);
/**
* 订阅的数据承载
*/
...
...
@@ -68,6 +71,7 @@ public final class DefaultMqttClientSession implements IMqttClientSession {
for
(
MqttClientSubscription
subscription
:
subscriptionSet
)
{
// 1. 已经存在订阅
if
(
clientSubscription
.
equals
(
subscription
))
{
logger
.
error
(
"MQTT Topic:{} mqttQoS:{} listener:{} duplicate subscription."
,
topicFilter
,
mqttQoS
,
listener
);
return
true
;
}
MqttQoS
subQos
=
subscription
.
getMqttQoS
();
...
...
@@ -77,6 +81,9 @@ public final class DefaultMqttClientSession implements IMqttClientSession {
// 3. 监听器不相同则直接添加
if
(
subListener
!=
listener
)
{
subscriptions
.
add
(
topicFilter
,
clientSubscription
);
logger
.
warn
(
"MQTT Topic:{} mqttQoS:{} listener:{} has a higher level qos, added directly."
,
topicFilter
,
mqttQoS
,
listener
);
}
else
{
logger
.
error
(
"MQTT Topic:{} mqttQoS:{} listener:{} has a higher level qos, duplicate subscription."
,
topicFilter
,
mqttQoS
,
listener
);
}
return
true
;
}
...
...
mica-mqtt-core/src/main/java/net/dreamlu/iot/mqtt/core/client/MqttClient.java
浏览文件 @
6fb20678
...
...
@@ -98,22 +98,22 @@ public final class MqttClient {
* @return MqttClient
*/
public
MqttClient
subscribe
(
MqttQoS
mqttQoS
,
String
topicFilter
,
IMqttClientMessageListener
listener
)
{
// 先判断是否已经订阅过,重复订阅
// 先判断是否已经订阅过,重复订阅
,直接跳出
boolean
subscribed
=
clientSession
.
isSubscribed
(
topicFilter
,
mqttQoS
,
listener
);
if
(
subscribed
)
{
logger
.
error
(
"MQTT Topic:{} mqttQoS:{} listener:{} duplicate subscription."
,
topicFilter
,
mqttQoS
,
listener
);
}
else
{
int
messageId
=
MqttClientMessageId
.
getId
();
MqttSubscribeMessage
message
=
MqttMessageBuilders
.
subscribe
()
.
addSubscription
(
mqttQoS
,
topicFilter
)
.
messageId
(
messageId
)
.
build
();
MqttPendingSubscription
pendingSubscription
=
new
MqttPendingSubscription
(
mqttQoS
,
topicFilter
,
listener
,
message
);
Boolean
result
=
Tio
.
send
(
context
,
message
);
logger
.
info
(
"MQTT Topic:{} mqttQoS:{} messageId:{} subscribing result:{}"
,
topicFilter
,
mqttQoS
,
messageId
,
result
);
pendingSubscription
.
startRetransmitTimer
(
executor
,
(
msg
)
->
Tio
.
send
(
context
,
message
));
clientSession
.
addPaddingSubscribe
(
messageId
,
pendingSubscription
);
return
this
;
}
// 没有订阅过
int
messageId
=
MqttClientMessageId
.
getId
();
MqttSubscribeMessage
message
=
MqttMessageBuilders
.
subscribe
()
.
addSubscription
(
mqttQoS
,
topicFilter
)
.
messageId
(
messageId
)
.
build
();
MqttPendingSubscription
pendingSubscription
=
new
MqttPendingSubscription
(
mqttQoS
,
topicFilter
,
listener
,
message
);
Boolean
result
=
Tio
.
send
(
context
,
message
);
logger
.
info
(
"MQTT Topic:{} mqttQoS:{} messageId:{} subscribing result:{}"
,
topicFilter
,
mqttQoS
,
messageId
,
result
);
pendingSubscription
.
startRetransmitTimer
(
executor
,
(
msg
)
->
Tio
.
send
(
context
,
message
));
clientSession
.
addPaddingSubscribe
(
messageId
,
pendingSubscription
);
return
this
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录