Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
e010ca74
R
Rocketmq
项目概览
Apache RocketMQ
/
Rocketmq
上一次同步 大约 3 年
通知
270
Star
16139
Fork
68
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
Rocketmq
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
e010ca74
编写于
5月 07, 2019
作者:
C
chengxiangwang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
polish data structure of IOTClientManager;add message forward logic
上级
4f8cd91c
变更
15
展开全部
隐藏空白更改
内联
并排
Showing
15 changed file
with
539 addition
and
178 deletion
+539
-178
client/src/test/java/org/apache/rocketmq/client/consumer/DefaultMQPullConsumerTest.java
...e/rocketmq/client/consumer/DefaultMQPullConsumerTest.java
+1
-1
client/src/test/java/org/apache/rocketmq/client/consumer/DefaultMQPushConsumerTest.java
...e/rocketmq/client/consumer/DefaultMQPushConsumerTest.java
+1
-1
common/pom.xml
common/pom.xml
+2
-2
common/src/main/java/org/apache/rocketmq/common/MqttConfig.java
.../src/main/java/org/apache/rocketmq/common/MqttConfig.java
+0
-1
mqtt/pom.xml
mqtt/pom.xml
+4
-0
mqtt/src/main/java/org/apache/rocketmq/mqtt/client/IOTClientManagerImpl.java
...org/apache/rocketmq/mqtt/client/IOTClientManagerImpl.java
+28
-5
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/MessageHandler.java
.../org/apache/rocketmq/mqtt/mqtthandler/MessageHandler.java
+54
-1
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttMessageForwarder.java
.../rocketmq/mqtt/mqtthandler/impl/MqttMessageForwarder.java
+24
-5
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttPublishMessageHandler.java
...etmq/mqtt/mqtthandler/impl/MqttPublishMessageHandler.java
+197
-72
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttSubscribeMessageHandler.java
...mq/mqtt/mqtthandler/impl/MqttSubscribeMessageHandler.java
+11
-17
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttUnsubscribeMessagHandler.java
...q/mqtt/mqtthandler/impl/MqttUnsubscribeMessagHandler.java
+22
-16
mqtt/src/main/java/org/apache/rocketmq/mqtt/processor/DefaultMqttMessageProcessor.java
.../rocketmq/mqtt/processor/DefaultMqttMessageProcessor.java
+3
-5
mqtt/src/main/java/org/apache/rocketmq/mqtt/processor/InnerMqttMessageProcessor.java
...he/rocketmq/mqtt/processor/InnerMqttMessageProcessor.java
+144
-0
mqtt/src/main/java/org/apache/rocketmq/mqtt/service/impl/MqttPushServiceImpl.java
...pache/rocketmq/mqtt/service/impl/MqttPushServiceImpl.java
+25
-41
snode/src/main/java/org/apache/rocketmq/snode/SnodeController.java
.../main/java/org/apache/rocketmq/snode/SnodeController.java
+23
-11
未找到文件。
client/src/test/java/org/apache/rocketmq/client/consumer/DefaultMQPullConsumerTest.java
浏览文件 @
e010ca74
...
@@ -51,7 +51,7 @@ import static org.mockito.ArgumentMatchers.nullable;
...
@@ -51,7 +51,7 @@ import static org.mockito.ArgumentMatchers.nullable;
import
static
org
.
mockito
.
Mockito
.
doAnswer
;
import
static
org
.
mockito
.
Mockito
.
doAnswer
;
import
static
org
.
mockito
.
Mockito
.
when
;
import
static
org
.
mockito
.
Mockito
.
when
;
@RunWith
(
MockitoJUnitRunner
.
class
)
@RunWith
(
MockitoJUnitRunner
.
Silent
.
class
)
public
class
DefaultMQPullConsumerTest
{
public
class
DefaultMQPullConsumerTest
{
@Spy
@Spy
private
MQClientInstance
mQClientFactory
=
MQClientManager
.
getInstance
().
getAndCreateMQClientInstance
(
new
ClientConfig
());
private
MQClientInstance
mQClientFactory
=
MQClientManager
.
getInstance
().
getAndCreateMQClientInstance
(
new
ClientConfig
());
...
...
client/src/test/java/org/apache/rocketmq/client/consumer/DefaultMQPushConsumerTest.java
浏览文件 @
e010ca74
...
@@ -73,7 +73,7 @@ import static org.mockito.Mockito.doReturn;
...
@@ -73,7 +73,7 @@ import static org.mockito.Mockito.doReturn;
import
static
org
.
mockito
.
Mockito
.
spy
;
import
static
org
.
mockito
.
Mockito
.
spy
;
import
static
org
.
mockito
.
Mockito
.
when
;
import
static
org
.
mockito
.
Mockito
.
when
;
@RunWith
(
MockitoJUnitRunner
.
class
)
@RunWith
(
MockitoJUnitRunner
.
Silent
.
class
)
public
class
DefaultMQPushConsumerTest
{
public
class
DefaultMQPushConsumerTest
{
private
String
consumerGroup
;
private
String
consumerGroup
;
private
String
topic
=
"FooBar"
;
private
String
topic
=
"FooBar"
;
...
...
common/pom.xml
浏览文件 @
e010ca74
...
@@ -46,7 +46,7 @@
...
@@ -46,7 +46,7 @@
<dependencies>
<dependencies>
<dependency>
<dependency>
<groupId>
org.apache.rocketmq
</groupId>
<groupId>
${project.groupId}
</groupId>
<artifactId>
rocketmq-remoting
</artifactId>
<artifactId>
rocketmq-remoting
</artifactId>
</dependency>
</dependency>
<dependency>
<dependency>
...
@@ -54,5 +54,5 @@
...
@@ -54,5 +54,5 @@
<artifactId>
snakeyaml
</artifactId>
<artifactId>
snakeyaml
</artifactId>
</dependency>
</dependency>
</dependencies>
</dependencies>
</project>
</project>
common/src/main/java/org/apache/rocketmq/common/MqttConfig.java
浏览文件 @
e010ca74
...
@@ -60,7 +60,6 @@ public class MqttConfig {
...
@@ -60,7 +60,6 @@ public class MqttConfig {
this
.
listenPort
=
listenPort
;
this
.
listenPort
=
listenPort
;
}
}
public
boolean
isAclEnable
()
{
public
boolean
isAclEnable
()
{
return
aclEnable
;
return
aclEnable
;
}
}
...
...
mqtt/pom.xml
浏览文件 @
e010ca74
...
@@ -99,5 +99,9 @@
...
@@ -99,5 +99,9 @@
<groupId>
${project.groupId}
</groupId>
<groupId>
${project.groupId}
</groupId>
<artifactId>
rocketmq-broker
</artifactId>
<artifactId>
rocketmq-broker
</artifactId>
</dependency>
</dependency>
<dependency>
<groupId>
org.eclipse.paho
</groupId>
<artifactId>
org.eclipse.paho.client.mqttv3
</artifactId>
</dependency>
</dependencies>
</dependencies>
</project>
</project>
mqtt/src/main/java/org/apache/rocketmq/mqtt/client/IOTClientManagerImpl.java
浏览文件 @
e010ca74
...
@@ -16,6 +16,7 @@
...
@@ -16,6 +16,7 @@
*/
*/
package
org.apache.rocketmq.mqtt.client
;
package
org.apache.rocketmq.mqtt.client
;
import
java.util.HashMap
;
import
java.util.Iterator
;
import
java.util.Iterator
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Map
;
...
@@ -25,10 +26,10 @@ import org.apache.rocketmq.common.client.Client;
...
@@ -25,10 +26,10 @@ import org.apache.rocketmq.common.client.Client;
import
org.apache.rocketmq.common.client.ClientManagerImpl
;
import
org.apache.rocketmq.common.client.ClientManagerImpl
;
import
org.apache.rocketmq.common.client.Subscription
;
import
org.apache.rocketmq.common.client.Subscription
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.protocol.heartbeat.SubscriptionData
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.eclipse.paho.client.mqttv3.MqttClient
;
public
class
IOTClientManagerImpl
extends
ClientManagerImpl
{
public
class
IOTClientManagerImpl
extends
ClientManagerImpl
{
...
@@ -36,9 +37,12 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
...
@@ -36,9 +37,12 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
public
static
final
String
IOT_GROUP
=
"IOT_GROUP"
;
public
static
final
String
IOT_GROUP
=
"IOT_GROUP"
;
private
final
ConcurrentHashMap
<
String
/*root topic*/
,
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>>
topic2SubscriptionTable
=
new
ConcurrentHashMap
<>(
// private final ConcurrentHashMap<String/*root topic*/, ConcurrentHashMap<Client, Set<SubscriptionData>>> topic2SubscriptionTable = new ConcurrentHashMap<>(
// 1024);
private
final
ConcurrentHashMap
<
String
/*root topic*/
,
Set
<
Client
>>
topic2Clients
=
new
ConcurrentHashMap
<>(
1024
);
1024
);
private
final
ConcurrentHashMap
<
String
/*clientId*/
,
Subscription
>
clientId2Subscription
=
new
ConcurrentHashMap
<>(
1024
);
private
final
ConcurrentHashMap
<
String
/*clientId*/
,
Subscription
>
clientId2Subscription
=
new
ConcurrentHashMap
<>(
1024
);
private
final
Map
<
String
/*snode ip*/
,
MqttClient
>
snode2MqttClient
=
new
HashMap
<>();
public
IOTClientManagerImpl
()
{
public
IOTClientManagerImpl
()
{
}
}
...
@@ -78,7 +82,7 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
...
@@ -78,7 +82,7 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
}
}
public
void
cleanSessionState
(
String
clientId
)
{
public
void
cleanSessionState
(
String
clientId
)
{
clientId2Subscription
.
remove
(
clientId
);
/*
clientId2Subscription.remove(clientId);
for (Iterator<Map.Entry<String, ConcurrentHashMap<Client, Set<SubscriptionData>>>> iterator = topic2SubscriptionTable.entrySet().iterator(); iterator.hasNext(); ) {
for (Iterator<Map.Entry<String, ConcurrentHashMap<Client, Set<SubscriptionData>>>> iterator = topic2SubscriptionTable.entrySet().iterator(); iterator.hasNext(); ) {
Map.Entry<String, ConcurrentHashMap<Client, Set<SubscriptionData>>> next = iterator.next();
Map.Entry<String, ConcurrentHashMap<Client, Set<SubscriptionData>>> next = iterator.next();
for (Iterator<Map.Entry<Client, Set<SubscriptionData>>> iterator1 = next.getValue().entrySet().iterator(); iterator1.hasNext(); ) {
for (Iterator<Map.Entry<Client, Set<SubscriptionData>>> iterator1 = next.getValue().entrySet().iterator(); iterator1.hasNext(); ) {
...
@@ -91,7 +95,18 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
...
@@ -91,7 +95,18 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
if (next.getValue() == null || next.getValue().size() == 0) {
if (next.getValue() == null || next.getValue().size() == 0) {
iterator.remove();
iterator.remove();
}
}
}*/
for
(
Iterator
<
Map
.
Entry
<
String
,
Set
<
Client
>>>
iterator
=
topic2Clients
.
entrySet
().
iterator
();
iterator
.
hasNext
();
)
{
Map
.
Entry
<
String
,
Set
<
Client
>>
next
=
iterator
.
next
();
Iterator
<
Client
>
iterator1
=
next
.
getValue
().
iterator
();
while
(
iterator1
.
hasNext
())
{
if
(
iterator1
.
next
().
getClientId
().
equals
(
clientId
))
{
iterator1
.
remove
();
}
}
}
}
clientId2Subscription
.
remove
(
clientId
);
//remove offline messages
//remove offline messages
}
}
...
@@ -99,8 +114,12 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
...
@@ -99,8 +114,12 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
return
clientId2Subscription
.
get
(
clientId
);
return
clientId2Subscription
.
get
(
clientId
);
}
}
public
ConcurrentHashMap
<
String
,
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>>
getTopic2SubscriptionTable
()
{
/* public ConcurrentHashMap<String, ConcurrentHashMap<Client, Set<SubscriptionData>>> getTopic2SubscriptionTable() {
return
topic2SubscriptionTable
;
return topic2SubscriptionTable;
}*/
public
ConcurrentHashMap
<
String
/*root topic*/
,
Set
<
Client
>>
getTopic2Clients
()
{
return
topic2Clients
;
}
}
public
ConcurrentHashMap
<
String
,
Subscription
>
getClientId2Subscription
()
{
public
ConcurrentHashMap
<
String
,
Subscription
>
getClientId2Subscription
()
{
...
@@ -110,4 +129,8 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
...
@@ -110,4 +129,8 @@ public class IOTClientManagerImpl extends ClientManagerImpl {
public
void
initSubscription
(
String
clientId
,
Subscription
subscription
)
{
public
void
initSubscription
(
String
clientId
,
Subscription
subscription
)
{
clientId2Subscription
.
put
(
clientId
,
subscription
);
clientId2Subscription
.
put
(
clientId
,
subscription
);
}
}
public
Map
<
String
,
MqttClient
>
getSnode2MqttClient
()
{
return
snode2MqttClient
;
}
}
}
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/MessageHandler.java
浏览文件 @
e010ca74
...
@@ -17,13 +17,25 @@
...
@@ -17,13 +17,25 @@
package
org.apache.rocketmq.mqtt.mqtthandler
;
package
org.apache.rocketmq.mqtt.mqtthandler
;
import
io.netty.handler.codec.mqtt.MqttFixedHeader
;
import
io.netty.handler.codec.mqtt.MqttMessage
;
import
io.netty.handler.codec.mqtt.MqttMessage
;
import
io.netty.handler.codec.mqtt.MqttMessageType
;
import
io.netty.handler.codec.mqtt.MqttQoS
;
import
java.util.Enumeration
;
import
java.util.HashSet
;
import
java.util.Set
;
import
java.util.concurrent.ConcurrentHashMap
;
import
org.apache.rocketmq.common.client.Client
;
import
org.apache.rocketmq.common.client.Subscription
;
import
org.apache.rocketmq.common.exception.MQClientException
;
import
org.apache.rocketmq.common.exception.MQClientException
;
import
org.apache.rocketmq.mqtt.client.IOTClientManagerImpl
;
import
org.apache.rocketmq.mqtt.util.MqttUtil
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.exception.RemotingConnectException
;
import
org.apache.rocketmq.remoting.exception.RemotingConnectException
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.exception.RemotingTimeoutException
;
import
org.apache.rocketmq.remoting.exception.RemotingTimeoutException
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.transport.mqtt.MqttHeader
;
public
interface
MessageHandler
{
public
interface
MessageHandler
{
...
@@ -32,5 +44,46 @@ public interface MessageHandler {
...
@@ -32,5 +44,46 @@ public interface MessageHandler {
*
*
* @param message
* @param message
*/
*/
RemotingCommand
handleMessage
(
MqttMessage
message
,
RemotingChannel
remotingChannel
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
,
MQClientException
;
RemotingCommand
handleMessage
(
MqttMessage
message
,
RemotingChannel
remotingChannel
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
,
MQClientException
;
default
Set
<
Client
>
findCurrentNodeClientsTobePublish
(
String
topic
,
IOTClientManagerImpl
iotClientManager
)
{
//find those clients publishing the message to
ConcurrentHashMap
<
String
,
Set
<
Client
>>
topic2Clients
=
iotClientManager
.
getTopic2Clients
();
ConcurrentHashMap
<
String
,
Subscription
>
clientId2Subscription
=
iotClientManager
.
getClientId2Subscription
();
Set
<
Client
>
clientsTobePush
=
new
HashSet
<>();
if
(
topic2Clients
.
containsKey
(
MqttUtil
.
getRootTopic
(
topic
)))
{
Set
<
Client
>
clients
=
topic2Clients
.
get
(
MqttUtil
.
getRootTopic
(
topic
));
for
(
Client
client
:
clients
)
{
Subscription
subscription
=
clientId2Subscription
.
get
(
client
.
getClientId
());
Enumeration
<
String
>
keys
=
subscription
.
getSubscriptionTable
().
keys
();
while
(
keys
.
hasMoreElements
())
{
String
topicFilter
=
keys
.
nextElement
();
if
(
MqttUtil
.
isMatch
(
topicFilter
,
topic
))
{
clientsTobePush
.
add
(
client
);
}
}
}
}
return
clientsTobePush
;
}
default
RemotingCommand
doResponse
(
MqttFixedHeader
fixedHeader
)
{
if
(
fixedHeader
.
qosLevel
().
value
()
>
0
)
{
RemotingCommand
command
=
RemotingCommand
.
createResponseCommand
(
MqttHeader
.
class
);
MqttHeader
mqttHeader
=
(
MqttHeader
)
command
.
readCustomHeader
();
if
(
fixedHeader
.
qosLevel
().
equals
(
MqttQoS
.
AT_MOST_ONCE
))
{
mqttHeader
.
setMessageType
(
MqttMessageType
.
PUBACK
.
value
());
mqttHeader
.
setDup
(
false
);
mqttHeader
.
setQosLevel
(
MqttQoS
.
AT_MOST_ONCE
.
value
());
mqttHeader
.
setRetain
(
false
);
mqttHeader
.
setRemainingLength
(
2
);
mqttHeader
.
setPacketId
(
0
);
}
else
if
(
fixedHeader
.
qosLevel
().
equals
(
MqttQoS
.
AT_LEAST_ONCE
))
{
//PUBREC/PUBREL/PUBCOMP
}
return
command
;
}
return
null
;
}
}
}
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttMessageForwarder.java
浏览文件 @
e010ca74
...
@@ -17,21 +17,29 @@
...
@@ -17,21 +17,29 @@
package
org.apache.rocketmq.mqtt.mqtthandler.impl
;
package
org.apache.rocketmq.mqtt.mqtthandler.impl
;
import
io.netty.buffer.ByteBuf
;
import
io.netty.handler.codec.mqtt.MqttFixedHeader
;
import
io.netty.handler.codec.mqtt.MqttMessage
;
import
io.netty.handler.codec.mqtt.MqttMessage
;
import
io.netty.handler.codec.mqtt.MqttPublishMessage
;
import
io.netty.handler.codec.mqtt.MqttPublishVariableHeader
;
import
io.netty.handler.codec.mqtt.MqttQoS
;
import
java.util.Set
;
import
org.apache.rocketmq.common.client.Client
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.mqtt.client.IOTClientManagerImpl
;
import
org.apache.rocketmq.mqtt.mqtthandler.MessageHandler
;
import
org.apache.rocketmq.mqtt.mqtthandler.MessageHandler
;
import
org.apache.rocketmq.mqtt.processor.
Default
MqttMessageProcessor
;
import
org.apache.rocketmq.mqtt.processor.
Inner
MqttMessageProcessor
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
public
class
MqttMessageForwarder
implements
MessageHandler
{
public
class
MqttMessageForwarder
implements
MessageHandler
{
private
static
final
InternalLogger
log
=
InternalLoggerFactory
.
getLogger
(
LoggerName
.
MQTT_LOGGER_NAME
);
private
static
final
InternalLogger
log
=
InternalLoggerFactory
.
getLogger
(
LoggerName
.
MQTT_LOGGER_NAME
);
private
final
DefaultMqttMessageProcessor
default
MqttMessageProcessor
;
private
final
InnerMqttMessageProcessor
inner
MqttMessageProcessor
;
public
MqttMessageForwarder
(
Default
MqttMessageProcessor
processor
)
{
public
MqttMessageForwarder
(
Inner
MqttMessageProcessor
processor
)
{
this
.
default
MqttMessageProcessor
=
processor
;
this
.
inner
MqttMessageProcessor
=
processor
;
}
}
/**
/**
...
@@ -41,6 +49,17 @@ public class MqttMessageForwarder implements MessageHandler {
...
@@ -41,6 +49,17 @@ public class MqttMessageForwarder implements MessageHandler {
* @return whether the message is handled successfully
* @return whether the message is handled successfully
*/
*/
@Override
public
RemotingCommand
handleMessage
(
MqttMessage
message
,
RemotingChannel
remotingChannel
)
{
@Override
public
RemotingCommand
handleMessage
(
MqttMessage
message
,
RemotingChannel
remotingChannel
)
{
return
null
;
MqttPublishMessage
mqttPublishMessage
=
(
MqttPublishMessage
)
message
;
MqttFixedHeader
fixedHeader
=
mqttPublishMessage
.
fixedHeader
();
MqttPublishVariableHeader
variableHeader
=
mqttPublishMessage
.
variableHeader
();
if
(
fixedHeader
.
qosLevel
().
equals
(
MqttQoS
.
AT_MOST_ONCE
))
{
ByteBuf
payload
=
mqttPublishMessage
.
payload
();
//Publish message to clients
Set
<
Client
>
clientsTobePublish
=
findCurrentNodeClientsTobePublish
(
variableHeader
.
topicName
(),
(
IOTClientManagerImpl
)
this
.
innerMqttMessageProcessor
.
getIotClientManager
());
innerMqttMessageProcessor
.
getDefaultMqttMessageProcessor
().
getMqttPushService
().
pushMessageQos0
(
variableHeader
.
topicName
(),
payload
,
clientsTobePublish
);
}
else
if
(
fixedHeader
.
qosLevel
().
equals
(
MqttQoS
.
AT_LEAST_ONCE
)){
//TODO
}
return
doResponse
(
fixedHeader
);
}
}
}
}
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttPublishMessageHandler.java
浏览文件 @
e010ca74
此差异已折叠。
点击以展开。
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttSubscribeMessageHandler.java
浏览文件 @
e010ca74
...
@@ -118,8 +118,8 @@ public class MqttSubscribeMessageHandler implements MessageHandler {
...
@@ -118,8 +118,8 @@ public class MqttSubscribeMessageHandler implements MessageHandler {
//do the logic when client sends subscribe packet.
//do the logic when client sends subscribe packet.
//1.update clientId2Subscription
//1.update clientId2Subscription
ConcurrentHashMap
<
String
,
Subscription
>
clientId2Subscription
=
iotClientManager
.
getClientId2Subscription
();
ConcurrentHashMap
<
String
,
Subscription
>
clientId2Subscription
=
iotClientManager
.
getClientId2Subscription
();
ConcurrentHashMap
<
String
,
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>>
topic2SubscriptionTable
=
iotClientManager
.
getTopic2SubscriptionTable
();
ConcurrentHashMap
<
String
,
Set
<
Client
>>
topic2Clients
=
iotClientManager
.
getTopic2Clients
();
Subscription
subscription
=
null
;
Subscription
subscription
;
if
(
clientId2Subscription
.
containsKey
(
client
.
getClientId
()))
{
if
(
clientId2Subscription
.
containsKey
(
client
.
getClientId
()))
{
subscription
=
clientId2Subscription
.
get
(
client
.
getClientId
());
subscription
=
clientId2Subscription
.
get
(
client
.
getClientId
());
}
else
{
}
else
{
...
@@ -133,23 +133,17 @@ public class MqttSubscribeMessageHandler implements MessageHandler {
...
@@ -133,23 +133,17 @@ public class MqttSubscribeMessageHandler implements MessageHandler {
grantQoss
.
add
(
actualQos
);
grantQoss
.
add
(
actualQos
);
SubscriptionData
subscriptionData
=
new
MqttSubscriptionData
(
mqttTopicSubscription
.
qualityOfService
().
value
(),
client
.
getClientId
(),
mqttTopicSubscription
.
topicName
());
SubscriptionData
subscriptionData
=
new
MqttSubscriptionData
(
mqttTopicSubscription
.
qualityOfService
().
value
(),
client
.
getClientId
(),
mqttTopicSubscription
.
topicName
());
subscriptionDatas
.
put
(
mqttTopicSubscription
.
topicName
(),
subscriptionData
);
subscriptionDatas
.
put
(
mqttTopicSubscription
.
topicName
(),
subscriptionData
);
//2.update topic2
SubscriptionTable
//2.update topic2
ClientIds
String
rootTopic
=
MqttUtil
.
getRootTopic
(
mqttTopicSubscription
.
topicName
());
String
rootTopic
=
MqttUtil
.
getRootTopic
(
mqttTopicSubscription
.
topicName
());
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>
client2SubscriptionData
=
topic2SubscriptionTable
.
get
(
rootTopic
);
if
(
topic2Clients
.
contains
(
rootTopic
))
{
if
(
client2SubscriptionData
==
null
||
client2SubscriptionData
.
size
()
==
0
)
{
final
Set
<
Client
>
clientIds
=
topic2Clients
.
get
(
rootTopic
);
client2SubscriptionData
=
new
ConcurrentHashMap
<>();
clientIds
.
add
(
client
);
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>
prev
=
topic2SubscriptionTable
.
putIfAbsent
(
rootTopic
,
client2SubscriptionData
);
}
else
{
Set
<
Client
>
clients
=
new
HashSet
<>();
clients
.
add
(
client
);
Set
<
Client
>
prev
=
topic2Clients
.
putIfAbsent
(
rootTopic
,
clients
);
if
(
prev
!=
null
)
{
if
(
prev
!=
null
)
{
client2SubscriptionData
=
prev
;
prev
.
add
(
client
);
}
Set
<
SubscriptionData
>
subscriptionDataSet
=
client2SubscriptionData
.
get
(
client
);
if
(
subscriptionDataSet
==
null
)
{
subscriptionDataSet
=
new
HashSet
<>();
Set
<
SubscriptionData
>
prevSubscriptionDataSet
=
client2SubscriptionData
.
putIfAbsent
(
client
,
subscriptionDataSet
);
if
(
prevSubscriptionDataSet
!=
null
)
{
subscriptionDataSet
=
prevSubscriptionDataSet
;
}
subscriptionDataSet
.
add
(
subscriptionData
);
}
}
}
}
}
}
...
...
mqtt/src/main/java/org/apache/rocketmq/mqtt/mqtthandler/impl/MqttUnsubscribeMessagHandler.java
浏览文件 @
e010ca74
...
@@ -25,6 +25,7 @@ import io.netty.handler.codec.mqtt.MqttUnsubscribeMessage;
...
@@ -25,6 +25,7 @@ import io.netty.handler.codec.mqtt.MqttUnsubscribeMessage;
import
io.netty.handler.codec.mqtt.MqttUnsubscribePayload
;
import
io.netty.handler.codec.mqtt.MqttUnsubscribePayload
;
import
java.util.Iterator
;
import
java.util.Iterator
;
import
java.util.List
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.Set
;
import
java.util.concurrent.ConcurrentHashMap
;
import
java.util.concurrent.ConcurrentHashMap
;
import
org.apache.rocketmq.common.client.Client
;
import
org.apache.rocketmq.common.client.Client
;
...
@@ -99,27 +100,32 @@ public class MqttUnsubscribeMessagHandler implements MessageHandler {
...
@@ -99,27 +100,32 @@ public class MqttUnsubscribeMessagHandler implements MessageHandler {
private
void
doUnsubscribe
(
Client
client
,
List
<
String
>
topics
,
IOTClientManagerImpl
iotClientManager
)
{
private
void
doUnsubscribe
(
Client
client
,
List
<
String
>
topics
,
IOTClientManagerImpl
iotClientManager
)
{
ConcurrentHashMap
<
String
,
Subscription
>
clientId2Subscription
=
iotClientManager
.
getClientId2Subscription
();
ConcurrentHashMap
<
String
,
Subscription
>
clientId2Subscription
=
iotClientManager
.
getClientId2Subscription
();
ConcurrentHashMap
<
String
,
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>>
topic2SubscriptionTable
=
iotClientManager
.
getTopic2SubscriptionTable
();
ConcurrentHashMap
<
String
,
Set
<
Client
>>
topic2Clients
=
iotClientManager
.
getTopic2Clients
();
Subscription
subscription
=
clientId2Subscription
.
get
(
client
.
getClientId
());
for
(
String
topicFilter
:
topics
)
{
//1.update clientId2Subscription
//1.update clientId2Subscription
if
(
clientId2Subscription
.
containsKey
(
client
.
getClientId
()))
{
if
(
clientId2Subscription
.
containsKey
(
client
.
getClientId
()))
{
for
(
String
topicFilter
:
topics
)
{
Subscription
subscription
=
clientId2Subscription
.
get
(
client
.
getClientId
());
subscription
.
getSubscriptionTable
().
remove
(
topicFilter
);
subscription
.
getSubscriptionTable
().
remove
(
topicFilter
);
}
}
//2.update topic2SubscriptionTable
}
String
rootTopic
=
MqttUtil
.
getRootTopic
(
topicFilter
);
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>
client2SubscriptionData
=
topic2SubscriptionTable
.
get
(
rootTopic
);
for
(
Iterator
<
Map
.
Entry
<
String
,
Set
<
Client
>>>
iterator
=
topic2Clients
.
entrySet
().
iterator
();
iterator
.
hasNext
();
)
{
if
(
client2SubscriptionData
!=
null
)
{
Map
.
Entry
<
String
,
Set
<
Client
>>
next
=
iterator
.
next
();
Set
<
SubscriptionData
>
subscriptionDataSet
=
client2SubscriptionData
.
get
(
client
);
String
rootTopic
=
next
.
getKey
();
if
(
subscriptionDataSet
!=
null
)
{
boolean
needRemove
=
true
;
Iterator
<
SubscriptionData
>
iterator
=
subscriptionDataSet
.
iterator
();
for
(
Map
.
Entry
<
String
,
SubscriptionData
>
entry
:
subscription
.
getSubscriptionTable
().
entrySet
())
{
while
(
iterator
.
hasNext
())
{
if
(
MqttUtil
.
getRootTopic
(
entry
.
getKey
()).
equals
(
rootTopic
))
{
if
(
iterator
.
next
().
getTopic
().
equals
(
topicFilter
))
needRemove
=
false
;
iterator
.
remove
();
break
;
}
}
}
}
}
if
(
needRemove
)
{
next
.
getValue
().
remove
(
client
);
}
if
(
next
.
getValue
().
size
()
==
0
)
{
iterator
.
remove
();
}
}
}
}
}
}
}
mqtt/src/main/java/org/apache/rocketmq/mqtt/processor/DefaultMqttMessageProcessor.java
浏览文件 @
e010ca74
...
@@ -30,7 +30,6 @@ import io.netty.handler.codec.mqtt.MqttPublishVariableHeader;
...
@@ -30,7 +30,6 @@ import io.netty.handler.codec.mqtt.MqttPublishVariableHeader;
import
io.netty.handler.codec.mqtt.MqttQoS
;
import
io.netty.handler.codec.mqtt.MqttQoS
;
import
io.netty.handler.codec.mqtt.MqttSubscribeMessage
;
import
io.netty.handler.codec.mqtt.MqttSubscribeMessage
;
import
io.netty.handler.codec.mqtt.MqttSubscribePayload
;
import
io.netty.handler.codec.mqtt.MqttSubscribePayload
;
import
java.io.UnsupportedEncodingException
;
import
java.util.HashMap
;
import
java.util.HashMap
;
import
java.util.Map
;
import
java.util.Map
;
import
org.apache.rocketmq.common.MqttConfig
;
import
org.apache.rocketmq.common.MqttConfig
;
...
@@ -61,7 +60,6 @@ import org.apache.rocketmq.mqtt.service.impl.WillMessageServiceImpl;
...
@@ -61,7 +60,6 @@ import org.apache.rocketmq.mqtt.service.impl.WillMessageServiceImpl;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingServer
;
import
org.apache.rocketmq.remoting.RemotingServer
;
import
org.apache.rocketmq.remoting.RequestProcessor
;
import
org.apache.rocketmq.remoting.RequestProcessor
;
import
org.apache.rocketmq.remoting.exception.RemotingCommandException
;
import
org.apache.rocketmq.remoting.exception.RemotingConnectException
;
import
org.apache.rocketmq.remoting.exception.RemotingConnectException
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.exception.RemotingTimeoutException
;
import
org.apache.rocketmq.remoting.exception.RemotingTimeoutException
;
...
@@ -85,7 +83,8 @@ public class DefaultMqttMessageProcessor implements RequestProcessor {
...
@@ -85,7 +83,8 @@ public class DefaultMqttMessageProcessor implements RequestProcessor {
private
EnodeService
enodeService
;
private
EnodeService
enodeService
;
private
NnodeService
nnodeService
;
private
NnodeService
nnodeService
;
public
DefaultMqttMessageProcessor
(
MqttConfig
mqttConfig
,
SnodeConfig
snodeConfig
,
RemotingServer
mqttRemotingServer
,
public
DefaultMqttMessageProcessor
(
MqttConfig
mqttConfig
,
SnodeConfig
snodeConfig
,
RemotingServer
mqttRemotingServer
,
EnodeService
enodeService
,
NnodeService
nnodeService
)
{
EnodeService
enodeService
,
NnodeService
nnodeService
)
{
this
.
mqttConfig
=
mqttConfig
;
this
.
mqttConfig
=
mqttConfig
;
this
.
snodeConfig
=
snodeConfig
;
this
.
snodeConfig
=
snodeConfig
;
...
@@ -119,7 +118,7 @@ public class DefaultMqttMessageProcessor implements RequestProcessor {
...
@@ -119,7 +118,7 @@ public class DefaultMqttMessageProcessor implements RequestProcessor {
@Override
@Override
public
RemotingCommand
processRequest
(
RemotingChannel
remotingChannel
,
RemotingCommand
message
)
public
RemotingCommand
processRequest
(
RemotingChannel
remotingChannel
,
RemotingCommand
message
)
throws
RemotingCommandException
,
UnsupportedEncodingException
,
InterruptedException
,
RemotingTimeoutException
,
MQClientException
,
RemotingSendRequestException
,
RemotingConnectException
{
throws
InterruptedException
,
RemotingTimeoutException
,
MQClientException
,
RemotingSendRequestException
,
RemotingConnectException
{
MqttHeader
mqttHeader
=
(
MqttHeader
)
message
.
readCustomHeader
();
MqttHeader
mqttHeader
=
(
MqttHeader
)
message
.
readCustomHeader
();
MqttFixedHeader
fixedHeader
=
new
MqttFixedHeader
(
MqttMessageType
.
valueOf
(
mqttHeader
.
getMessageType
()),
MqttFixedHeader
fixedHeader
=
new
MqttFixedHeader
(
MqttMessageType
.
valueOf
(
mqttHeader
.
getMessageType
()),
mqttHeader
.
isDup
(),
MqttQoS
.
valueOf
(
mqttHeader
.
getQosLevel
()),
mqttHeader
.
isRetain
(),
mqttHeader
.
isDup
(),
MqttQoS
.
valueOf
(
mqttHeader
.
getQosLevel
()),
mqttHeader
.
isRetain
(),
...
@@ -132,7 +131,6 @@ public class DefaultMqttMessageProcessor implements RequestProcessor {
...
@@ -132,7 +131,6 @@ public class DefaultMqttMessageProcessor implements RequestProcessor {
mqttHeader
.
isHasPassword
(),
mqttHeader
.
isWillRetain
(),
mqttHeader
.
isHasPassword
(),
mqttHeader
.
isWillRetain
(),
mqttHeader
.
getWillQos
(),
mqttHeader
.
isWillFlag
(),
mqttHeader
.
getWillQos
(),
mqttHeader
.
isWillFlag
(),
mqttHeader
.
isCleanSession
(),
mqttHeader
.
getKeepAliveTimeSeconds
());
mqttHeader
.
isCleanSession
(),
mqttHeader
.
getKeepAliveTimeSeconds
());
// MqttConnectPayload mqttConnectPayload = (MqttConnectPayload) message.getPayload();
MqttConnectPayload
mqttConnectPayload
=
(
MqttConnectPayload
)
MqttEncodeDecodeUtil
.
decode
(
message
.
getBody
(),
MqttConnectPayload
.
class
);
MqttConnectPayload
mqttConnectPayload
=
(
MqttConnectPayload
)
MqttEncodeDecodeUtil
.
decode
(
message
.
getBody
(),
MqttConnectPayload
.
class
);
mqttMessage
=
new
MqttConnectMessage
(
fixedHeader
,
mqttConnectVariableHeader
,
mqttConnectPayload
);
mqttMessage
=
new
MqttConnectMessage
(
fixedHeader
,
mqttConnectVariableHeader
,
mqttConnectPayload
);
break
;
break
;
...
...
mqtt/src/main/java/org/apache/rocketmq/mqtt/processor/InnerMqttMessageProcessor.java
0 → 100644
浏览文件 @
e010ca74
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package
org.apache.rocketmq.mqtt.processor
;
import
io.netty.buffer.Unpooled
;
import
io.netty.handler.codec.mqtt.MqttFixedHeader
;
import
io.netty.handler.codec.mqtt.MqttMessage
;
import
io.netty.handler.codec.mqtt.MqttMessageType
;
import
io.netty.handler.codec.mqtt.MqttPublishMessage
;
import
io.netty.handler.codec.mqtt.MqttPublishVariableHeader
;
import
io.netty.handler.codec.mqtt.MqttQoS
;
import
org.apache.rocketmq.common.MqttConfig
;
import
org.apache.rocketmq.common.SnodeConfig
;
import
org.apache.rocketmq.common.client.ClientManager
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.exception.MQClientException
;
import
org.apache.rocketmq.common.service.EnodeService
;
import
org.apache.rocketmq.common.service.NnodeService
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.mqtt.mqtthandler.impl.MqttMessageForwarder
;
import
org.apache.rocketmq.mqtt.service.WillMessageService
;
import
org.apache.rocketmq.mqtt.service.impl.MqttPushServiceImpl
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingServer
;
import
org.apache.rocketmq.remoting.RequestProcessor
;
import
org.apache.rocketmq.remoting.exception.RemotingConnectException
;
import
org.apache.rocketmq.remoting.exception.RemotingSendRequestException
;
import
org.apache.rocketmq.remoting.exception.RemotingTimeoutException
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.transport.mqtt.MqttHeader
;
import
static
io
.
netty
.
handler
.
codec
.
mqtt
.
MqttMessageType
.
PUBLISH
;
public
class
InnerMqttMessageProcessor
implements
RequestProcessor
{
private
static
final
InternalLogger
log
=
InternalLoggerFactory
.
getLogger
(
LoggerName
.
MQTT_LOGGER_NAME
);
private
final
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
;
private
WillMessageService
willMessageService
;
private
MqttPushServiceImpl
mqttPushService
;
private
ClientManager
iotClientManager
;
private
RemotingServer
innerMqttRemotingServer
;
private
MqttConfig
mqttConfig
;
private
SnodeConfig
snodeConfig
;
private
EnodeService
enodeService
;
private
NnodeService
nnodeService
;
private
MqttMessageForwarder
mqttMessageForwarder
;
public
InnerMqttMessageProcessor
(
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
,
RemotingServer
innerMqttRemotingServer
)
{
this
.
defaultMqttMessageProcessor
=
defaultMqttMessageProcessor
;
this
.
willMessageService
=
this
.
defaultMqttMessageProcessor
.
getWillMessageService
();
this
.
mqttPushService
=
this
.
defaultMqttMessageProcessor
.
getMqttPushService
();
this
.
iotClientManager
=
this
.
defaultMqttMessageProcessor
.
getIotClientManager
();
this
.
innerMqttRemotingServer
=
innerMqttRemotingServer
;
this
.
enodeService
=
this
.
defaultMqttMessageProcessor
.
getEnodeService
();
this
.
nnodeService
=
this
.
defaultMqttMessageProcessor
.
getNnodeService
();
this
.
mqttMessageForwarder
=
new
MqttMessageForwarder
(
this
);
}
@Override
public
RemotingCommand
processRequest
(
RemotingChannel
remotingChannel
,
RemotingCommand
message
)
throws
InterruptedException
,
RemotingTimeoutException
,
MQClientException
,
RemotingSendRequestException
,
RemotingConnectException
{
MqttHeader
mqttHeader
=
(
MqttHeader
)
message
.
readCustomHeader
();
if
(
mqttHeader
.
getMessageType
().
equals
(
PUBLISH
)){
MqttFixedHeader
fixedHeader
=
new
MqttFixedHeader
(
MqttMessageType
.
valueOf
(
mqttHeader
.
getMessageType
()),
mqttHeader
.
isDup
(),
MqttQoS
.
valueOf
(
mqttHeader
.
getQosLevel
()),
mqttHeader
.
isRetain
(),
mqttHeader
.
getRemainingLength
());
MqttPublishVariableHeader
mqttPublishVariableHeader
=
new
MqttPublishVariableHeader
(
mqttHeader
.
getTopicName
(),
mqttHeader
.
getPacketId
());
MqttMessage
mqttMessage
=
new
MqttPublishMessage
(
fixedHeader
,
mqttPublishVariableHeader
,
Unpooled
.
copiedBuffer
(
message
.
getBody
()));
return
mqttMessageForwarder
.
handleMessage
(
mqttMessage
,
remotingChannel
);
}
else
{
return
defaultMqttMessageProcessor
.
processRequest
(
remotingChannel
,
message
);
}
}
@Override
public
boolean
rejectRequest
()
{
return
false
;
}
public
WillMessageService
getWillMessageService
()
{
return
willMessageService
;
}
public
MqttPushServiceImpl
getMqttPushService
()
{
return
mqttPushService
;
}
public
ClientManager
getIotClientManager
()
{
return
iotClientManager
;
}
public
MqttConfig
getMqttConfig
()
{
return
mqttConfig
;
}
public
void
setMqttConfig
(
MqttConfig
mqttConfig
)
{
this
.
mqttConfig
=
mqttConfig
;
}
public
SnodeConfig
getSnodeConfig
()
{
return
snodeConfig
;
}
public
void
setSnodeConfig
(
SnodeConfig
snodeConfig
)
{
this
.
snodeConfig
=
snodeConfig
;
}
public
EnodeService
getEnodeService
()
{
return
enodeService
;
}
public
void
setEnodeService
(
EnodeService
enodeService
)
{
this
.
enodeService
=
enodeService
;
}
public
NnodeService
getNnodeService
()
{
return
nnodeService
;
}
public
void
setNnodeService
(
NnodeService
nnodeService
)
{
this
.
nnodeService
=
nnodeService
;
}
public
DefaultMqttMessageProcessor
getDefaultMqttMessageProcessor
()
{
return
defaultMqttMessageProcessor
;
}
}
mqtt/src/main/java/org/apache/rocketmq/mqtt/service/impl/MqttPushServiceImpl.java
浏览文件 @
e010ca74
...
@@ -19,11 +19,8 @@ package org.apache.rocketmq.mqtt.service.impl;
...
@@ -19,11 +19,8 @@ package org.apache.rocketmq.mqtt.service.impl;
import
io.netty.buffer.ByteBuf
;
import
io.netty.buffer.ByteBuf
;
import
io.netty.handler.codec.mqtt.MqttMessageType
;
import
io.netty.handler.codec.mqtt.MqttMessageType
;
import
io.netty.util.ReferenceCountUtil
;
import
io.netty.util.ReferenceCountUtil
;
import
java.util.HashSet
;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.Set
;
import
java.util.concurrent.ArrayBlockingQueue
;
import
java.util.concurrent.ArrayBlockingQueue
;
import
java.util.concurrent.ConcurrentHashMap
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.TimeUnit
;
import
java.util.concurrent.TimeUnit
;
import
java.util.concurrent.atomic.AtomicBoolean
;
import
java.util.concurrent.atomic.AtomicBoolean
;
...
@@ -31,14 +28,11 @@ import org.apache.rocketmq.common.MqttConfig;
...
@@ -31,14 +28,11 @@ import org.apache.rocketmq.common.MqttConfig;
import
org.apache.rocketmq.common.client.Client
;
import
org.apache.rocketmq.common.client.Client
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
import
org.apache.rocketmq.common.protocol.heartbeat.SubscriptionData
;
import
org.apache.rocketmq.common.utils.ThreadUtils
;
import
org.apache.rocketmq.common.utils.ThreadUtils
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.mqtt.client.IOTClientManagerImpl
;
import
org.apache.rocketmq.mqtt.constant.MqttConstant
;
import
org.apache.rocketmq.mqtt.constant.MqttConstant
;
import
org.apache.rocketmq.mqtt.processor.DefaultMqttMessageProcessor
;
import
org.apache.rocketmq.mqtt.processor.DefaultMqttMessageProcessor
;
import
org.apache.rocketmq.mqtt.util.MqttUtil
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.netty.NettyChannelHandlerContextImpl
;
import
org.apache.rocketmq.remoting.netty.NettyChannelHandlerContextImpl
;
import
org.apache.rocketmq.remoting.netty.NettyChannelImpl
;
import
org.apache.rocketmq.remoting.netty.NettyChannelImpl
;
...
@@ -49,7 +43,7 @@ public class MqttPushServiceImpl {
...
@@ -49,7 +43,7 @@ public class MqttPushServiceImpl {
private
static
final
InternalLogger
log
=
InternalLoggerFactory
.
getLogger
(
LoggerName
.
MQTT_LOGGER_NAME
);
private
static
final
InternalLogger
log
=
InternalLoggerFactory
.
getLogger
(
LoggerName
.
MQTT_LOGGER_NAME
);
private
ExecutorService
pushMqttMessageExecutorService
;
private
ExecutorService
pushMqttMessageExecutorService
;
private
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
;
private
static
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
;
public
MqttPushServiceImpl
(
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
,
MqttConfig
mqttConfig
)
{
public
MqttPushServiceImpl
(
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
,
MqttConfig
mqttConfig
)
{
this
.
defaultMqttMessageProcessor
=
defaultMqttMessageProcessor
;
this
.
defaultMqttMessageProcessor
=
defaultMqttMessageProcessor
;
...
@@ -63,21 +57,23 @@ public class MqttPushServiceImpl {
...
@@ -63,21 +57,23 @@ public class MqttPushServiceImpl {
false
);
false
);
}
}
publ
ic
class
MqttPushTask
implements
Runnable
{
stat
ic
class
MqttPushTask
implements
Runnable
{
private
AtomicBoolean
canceled
=
new
AtomicBoolean
(
false
);
private
AtomicBoolean
canceled
=
new
AtomicBoolean
(
false
);
private
final
ByteBuf
message
;
private
final
ByteBuf
message
;
private
final
String
topic
;
private
final
String
topic
;
private
final
Integer
qos
;
private
final
Integer
qos
;
private
boolean
retain
;
private
boolean
retain
;
private
Integer
packetId
;
private
Integer
packetId
;
private
Client
client
;
public
MqttPushTask
(
final
String
topic
,
final
ByteBuf
message
,
final
Integer
qos
,
boolean
retain
,
public
MqttPushTask
(
final
String
topic
,
final
ByteBuf
message
,
final
Integer
qos
,
boolean
retain
,
Integer
packetId
)
{
Integer
packetId
,
Client
client
)
{
this
.
message
=
message
;
this
.
message
=
message
;
this
.
topic
=
topic
;
this
.
topic
=
topic
;
this
.
qos
=
qos
;
this
.
qos
=
qos
;
this
.
retain
=
retain
;
this
.
retain
=
retain
;
this
.
packetId
=
packetId
;
this
.
packetId
=
packetId
;
this
.
client
=
client
;
}
}
@Override
@Override
...
@@ -86,32 +82,14 @@ public class MqttPushServiceImpl {
...
@@ -86,32 +82,14 @@ public class MqttPushServiceImpl {
try
{
try
{
RemotingCommand
requestCommand
=
buildRequestCommand
(
topic
,
qos
,
retain
,
packetId
);
RemotingCommand
requestCommand
=
buildRequestCommand
(
topic
,
qos
,
retain
,
packetId
);
//find those clients publishing the message to
RemotingChannel
remotingChannel
=
client
.
getRemotingChannel
();
IOTClientManagerImpl
iotClientManager
=
(
IOTClientManagerImpl
)
defaultMqttMessageProcessor
.
getIotClientManager
();
if
(
client
.
getRemotingChannel
()
instanceof
NettyChannelHandlerContextImpl
)
{
ConcurrentHashMap
<
String
,
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>>
topic2SubscriptionTable
=
iotClientManager
.
getTopic2SubscriptionTable
();
remotingChannel
=
new
NettyChannelImpl
(((
NettyChannelHandlerContextImpl
)
client
.
getRemotingChannel
()).
getChannelHandlerContext
().
channel
());
Set
<
Client
>
clients
=
new
HashSet
<>();
if
(
topic2SubscriptionTable
.
containsKey
(
MqttUtil
.
getRootTopic
(
topic
)))
{
ConcurrentHashMap
<
Client
,
Set
<
SubscriptionData
>>
client2SubscriptionDatas
=
topic2SubscriptionTable
.
get
(
MqttUtil
.
getRootTopic
(
topic
));
for
(
Map
.
Entry
<
Client
,
Set
<
SubscriptionData
>>
entry
:
client2SubscriptionDatas
.
entrySet
())
{
Set
<
SubscriptionData
>
subscriptionDatas
=
entry
.
getValue
();
for
(
SubscriptionData
subscriptionData
:
subscriptionDatas
)
{
if
(
MqttUtil
.
isMatch
(
subscriptionData
.
getTopic
(),
topic
))
{
clients
.
add
(
entry
.
getKey
());
break
;
}
}
}
}
for
(
Client
client
:
clients
)
{
RemotingChannel
remotingChannel
=
client
.
getRemotingChannel
();
if
(
client
.
getRemotingChannel
()
instanceof
NettyChannelHandlerContextImpl
)
{
remotingChannel
=
new
NettyChannelImpl
(((
NettyChannelHandlerContextImpl
)
client
.
getRemotingChannel
()).
getChannelHandlerContext
().
channel
());
}
byte
[]
body
=
new
byte
[
message
.
readableBytes
()];
message
.
readBytes
(
body
);
requestCommand
.
setBody
(
body
);
defaultMqttMessageProcessor
.
getMqttRemotingServer
().
push
(
remotingChannel
,
requestCommand
,
MqttConstant
.
DEFAULT_TIMEOUT_MILLS
);
}
}
byte
[]
body
=
new
byte
[
message
.
readableBytes
()];
message
.
readBytes
(
body
);
requestCommand
.
setBody
(
body
);
defaultMqttMessageProcessor
.
getMqttRemotingServer
().
push
(
remotingChannel
,
requestCommand
,
MqttConstant
.
DEFAULT_TIMEOUT_MILLS
);
}
catch
(
Exception
ex
)
{
}
catch
(
Exception
ex
)
{
log
.
warn
(
"Exception was thrown when pushing MQTT message to topic: {}, exception={}"
,
topic
,
ex
.
getMessage
());
log
.
warn
(
"Exception was thrown when pushing MQTT message to topic: {}, exception={}"
,
topic
,
ex
.
getMessage
());
}
finally
{
}
finally
{
...
@@ -147,15 +125,21 @@ public class MqttPushServiceImpl {
...
@@ -147,15 +125,21 @@ public class MqttPushServiceImpl {
}
}
public
void
pushMessageQos0
(
final
String
topic
,
final
ByteBuf
message
)
{
public
void
pushMessageQos0
(
final
String
topic
,
final
ByteBuf
message
,
Set
<
Client
>
clientsTobePublish
)
{
MqttPushTask
pushTask
=
new
MqttPushTask
(
topic
,
message
,
0
,
false
,
0
);
//For clientIds connected to the current snode
pushMqttMessageExecutorService
.
submit
(
pushTask
);
for
(
Client
client
:
clientsTobePublish
)
{
MqttPushTask
pushTask
=
new
MqttPushTask
(
topic
,
message
,
0
,
false
,
0
,
client
);
pushMqttMessageExecutorService
.
submit
(
pushTask
);
}
}
}
public
void
pushMessageQos1
(
final
String
topic
,
final
ByteBuf
message
,
final
Integer
qos
,
boolean
retain
,
public
void
pushMessageQos1
(
final
String
topic
,
final
ByteBuf
message
,
boolean
retain
,
Integer
packetId
,
Integer
packetId
)
{
Set
<
Client
>
clientsTobePublish
)
{
MqttPushTask
pushTask
=
new
MqttPushTask
(
topic
,
message
,
qos
,
retain
,
packetId
);
for
(
Client
client
:
clientsTobePublish
)
{
pushMqttMessageExecutorService
.
submit
(
pushTask
);
MqttPushTask
pushTask
=
new
MqttPushTask
(
topic
,
message
,
1
,
retain
,
packetId
,
client
);
pushMqttMessageExecutorService
.
submit
(
pushTask
);
}
}
}
public
void
shutdown
()
{
public
void
shutdown
()
{
...
...
snode/src/main/java/org/apache/rocketmq/snode/SnodeController.java
浏览文件 @
e010ca74
...
@@ -30,10 +30,17 @@ import org.apache.rocketmq.common.ThreadFactoryImpl;
...
@@ -30,10 +30,17 @@ import org.apache.rocketmq.common.ThreadFactoryImpl;
import
org.apache.rocketmq.common.client.ClientManager
;
import
org.apache.rocketmq.common.client.ClientManager
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
import
org.apache.rocketmq.common.service.ClientService
;
import
org.apache.rocketmq.common.service.EnodeService
;
import
org.apache.rocketmq.common.service.MetricsService
;
import
org.apache.rocketmq.common.service.NnodeService
;
import
org.apache.rocketmq.common.service.PushService
;
import
org.apache.rocketmq.common.service.ScheduledService
;
import
org.apache.rocketmq.common.utils.ThreadUtils
;
import
org.apache.rocketmq.common.utils.ThreadUtils
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.mqtt.processor.DefaultMqttMessageProcessor
;
import
org.apache.rocketmq.mqtt.processor.DefaultMqttMessageProcessor
;
import
org.apache.rocketmq.mqtt.processor.InnerMqttMessageProcessor
;
import
org.apache.rocketmq.remoting.ClientConfig
;
import
org.apache.rocketmq.remoting.ClientConfig
;
import
org.apache.rocketmq.remoting.RemotingClient
;
import
org.apache.rocketmq.remoting.RemotingClient
;
import
org.apache.rocketmq.remoting.RemotingClientFactory
;
import
org.apache.rocketmq.remoting.RemotingClientFactory
;
...
@@ -62,12 +69,6 @@ import org.apache.rocketmq.snode.processor.ConsumerManageProcessor;
...
@@ -62,12 +69,6 @@ import org.apache.rocketmq.snode.processor.ConsumerManageProcessor;
import
org.apache.rocketmq.snode.processor.HeartbeatProcessor
;
import
org.apache.rocketmq.snode.processor.HeartbeatProcessor
;
import
org.apache.rocketmq.snode.processor.PullMessageProcessor
;
import
org.apache.rocketmq.snode.processor.PullMessageProcessor
;
import
org.apache.rocketmq.snode.processor.SendMessageProcessor
;
import
org.apache.rocketmq.snode.processor.SendMessageProcessor
;
import
org.apache.rocketmq.common.service.ClientService
;
import
org.apache.rocketmq.common.service.EnodeService
;
import
org.apache.rocketmq.common.service.MetricsService
;
import
org.apache.rocketmq.common.service.NnodeService
;
import
org.apache.rocketmq.common.service.PushService
;
import
org.apache.rocketmq.common.service.ScheduledService
;
import
org.apache.rocketmq.snode.service.impl.ClientServiceImpl
;
import
org.apache.rocketmq.snode.service.impl.ClientServiceImpl
;
import
org.apache.rocketmq.snode.service.impl.LocalEnodeServiceImpl
;
import
org.apache.rocketmq.snode.service.impl.LocalEnodeServiceImpl
;
import
org.apache.rocketmq.snode.service.impl.MetricsServiceImpl
;
import
org.apache.rocketmq.snode.service.impl.MetricsServiceImpl
;
...
@@ -91,6 +92,7 @@ public class SnodeController {
...
@@ -91,6 +92,7 @@ public class SnodeController {
private
RemotingServer
snodeServer
;
private
RemotingServer
snodeServer
;
private
RemotingClient
mqttRemotingClient
;
private
RemotingClient
mqttRemotingClient
;
private
RemotingServer
mqttRemotingServer
;
private
RemotingServer
mqttRemotingServer
;
private
RemotingServer
innerMqttRemotingServer
;
private
ExecutorService
sendMessageExecutor
;
private
ExecutorService
sendMessageExecutor
;
private
ExecutorService
handleMqttMessageExecutor
;
private
ExecutorService
handleMqttMessageExecutor
;
private
ExecutorService
heartbeatExecutor
;
private
ExecutorService
heartbeatExecutor
;
...
@@ -101,7 +103,6 @@ public class SnodeController {
...
@@ -101,7 +103,6 @@ public class SnodeController {
private
ScheduledService
scheduledService
;
private
ScheduledService
scheduledService
;
private
ClientManager
producerManager
;
private
ClientManager
producerManager
;
private
ClientManager
consumerManager
;
private
ClientManager
consumerManager
;
// private ClientManager iotClientManager;
private
SubscriptionManager
subscriptionManager
;
private
SubscriptionManager
subscriptionManager
;
private
ClientHousekeepingService
clientHousekeepingService
;
private
ClientHousekeepingService
clientHousekeepingService
;
private
SubscriptionGroupManager
subscriptionGroupManager
;
private
SubscriptionGroupManager
subscriptionGroupManager
;
...
@@ -111,6 +112,7 @@ public class SnodeController {
...
@@ -111,6 +112,7 @@ public class SnodeController {
private
PullMessageProcessor
pullMessageProcessor
;
private
PullMessageProcessor
pullMessageProcessor
;
private
HeartbeatProcessor
heartbeatProcessor
;
private
HeartbeatProcessor
heartbeatProcessor
;
private
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
;
private
DefaultMqttMessageProcessor
defaultMqttMessageProcessor
;
private
InnerMqttMessageProcessor
innerMqttMessageProcessor
;
private
InterceptorGroup
remotingServerInterceptorGroup
;
private
InterceptorGroup
remotingServerInterceptorGroup
;
private
InterceptorGroup
consumeMessageInterceptorGroup
;
private
InterceptorGroup
consumeMessageInterceptorGroup
;
private
InterceptorGroup
sendMessageInterceptorGroup
;
private
InterceptorGroup
sendMessageInterceptorGroup
;
...
@@ -118,14 +120,12 @@ public class SnodeController {
...
@@ -118,14 +120,12 @@ public class SnodeController {
private
ClientService
clientService
;
private
ClientService
clientService
;
private
SlowConsumerService
slowConsumerService
;
private
SlowConsumerService
slowConsumerService
;
private
MetricsService
metricsService
;
private
MetricsService
metricsService
;
// private WillMessageService willMessageService;
// private MqttPushServiceImpl mqttPushService;
private
final
ScheduledExecutorService
scheduledExecutorService
=
Executors
private
final
ScheduledExecutorService
scheduledExecutorService
=
Executors
.
newSingleThreadScheduledExecutor
(
new
ThreadFactoryImpl
(
.
newSingleThreadScheduledExecutor
(
new
ThreadFactoryImpl
(
"SnodeControllerScheduledThread"
));
"SnodeControllerScheduledThread"
));
public
SnodeController
(
SnodeConfig
snodeConfig
,
MqttConfig
mqttConfig
)
{
public
SnodeController
(
SnodeConfig
snodeConfig
,
MqttConfig
mqttConfig
)
throws
CloneNotSupportedException
{
this
.
nettyClientConfig
=
snodeConfig
.
getNettyClientConfig
();
this
.
nettyClientConfig
=
snodeConfig
.
getNettyClientConfig
();
this
.
nettyServerConfig
=
snodeConfig
.
getNettyServerConfig
();
this
.
nettyServerConfig
=
snodeConfig
.
getNettyServerConfig
();
this
.
mqttServerConfig
=
mqttConfig
.
getMqttServerConfig
();
this
.
mqttServerConfig
=
mqttConfig
.
getMqttServerConfig
();
...
@@ -155,6 +155,14 @@ public class SnodeController {
...
@@ -155,6 +155,14 @@ public class SnodeController {
this
.
mqttRemotingServer
.
init
(
this
.
mqttServerConfig
,
this
.
clientHousekeepingService
);
this
.
mqttRemotingServer
.
init
(
this
.
mqttServerConfig
,
this
.
clientHousekeepingService
);
this
.
mqttRemotingServer
.
registerInterceptorGroup
(
this
.
remotingServerInterceptorGroup
);
this
.
mqttRemotingServer
.
registerInterceptorGroup
(
this
.
remotingServerInterceptorGroup
);
}
}
this
.
innerMqttRemotingServer
=
RemotingServerFactory
.
getInstance
().
createRemotingServer
(
RemotingUtil
.
MQTT_PROTOCOL
);
ServerConfig
innerMqttServerConfig
=
(
ServerConfig
)
mqttServerConfig
.
clone
();
innerMqttServerConfig
.
setListenPort
(
mqttServerConfig
.
getListenPort
()
-
1
);
if
(
this
.
innerMqttRemotingServer
!=
null
)
{
this
.
innerMqttRemotingServer
.
init
(
innerMqttServerConfig
,
this
.
clientHousekeepingService
);
this
.
innerMqttRemotingServer
.
registerInterceptorGroup
(
this
.
remotingServerInterceptorGroup
);
}
this
.
sendMessageExecutor
=
ThreadUtils
.
newThreadPoolExecutor
(
this
.
sendMessageExecutor
=
ThreadUtils
.
newThreadPoolExecutor
(
snodeConfig
.
getSnodeSendMessageMinPoolSize
(),
snodeConfig
.
getSnodeSendMessageMinPoolSize
(),
snodeConfig
.
getSnodeSendMessageMaxPoolSize
(),
snodeConfig
.
getSnodeSendMessageMaxPoolSize
(),
...
@@ -212,7 +220,8 @@ public class SnodeController {
...
@@ -212,7 +220,8 @@ public class SnodeController {
this
.
sendMessageProcessor
=
new
SendMessageProcessor
(
this
);
this
.
sendMessageProcessor
=
new
SendMessageProcessor
(
this
);
this
.
heartbeatProcessor
=
new
HeartbeatProcessor
(
this
);
this
.
heartbeatProcessor
=
new
HeartbeatProcessor
(
this
);
this
.
pullMessageProcessor
=
new
PullMessageProcessor
(
this
);
this
.
pullMessageProcessor
=
new
PullMessageProcessor
(
this
);
this
.
defaultMqttMessageProcessor
=
new
DefaultMqttMessageProcessor
(
this
.
mqttConfig
,
mqttRemotingServer
,
enodeService
,
nnodeService
);
this
.
defaultMqttMessageProcessor
=
new
DefaultMqttMessageProcessor
(
this
.
mqttConfig
,
this
.
snodeConfig
,
mqttRemotingServer
,
enodeService
,
nnodeService
);
this
.
innerMqttMessageProcessor
=
new
InnerMqttMessageProcessor
(
this
.
defaultMqttMessageProcessor
,
innerMqttRemotingServer
);
this
.
pushService
=
new
PushServiceImpl
(
this
);
this
.
pushService
=
new
PushServiceImpl
(
this
);
this
.
clientService
=
new
ClientServiceImpl
(
this
);
this
.
clientService
=
new
ClientServiceImpl
(
this
);
this
.
subscriptionManager
=
new
SubscriptionManagerImpl
();
this
.
subscriptionManager
=
new
SubscriptionManagerImpl
();
...
@@ -352,6 +361,9 @@ public class SnodeController {
...
@@ -352,6 +361,9 @@ public class SnodeController {
if
(
mqttRemotingServer
!=
null
)
{
if
(
mqttRemotingServer
!=
null
)
{
this
.
mqttRemotingServer
.
registerProcessor
(
RequestCode
.
MQTT_MESSAGE
,
defaultMqttMessageProcessor
,
handleMqttMessageExecutor
);
this
.
mqttRemotingServer
.
registerProcessor
(
RequestCode
.
MQTT_MESSAGE
,
defaultMqttMessageProcessor
,
handleMqttMessageExecutor
);
}
}
if
(
innerMqttRemotingServer
!=
null
)
{
this
.
innerMqttRemotingServer
.
registerProcessor
(
RequestCode
.
MQTT_MESSAGE
,
innerMqttMessageProcessor
,
handleMqttMessageExecutor
);
}
}
}
public
void
start
()
{
public
void
start
()
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录