Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
3706778b
R
Rocketmq
项目概览
Apache RocketMQ
/
Rocketmq
上一次同步 大约 3 年
通知
268
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看板
提交
3706778b
编写于
2月 23, 2019
作者:
D
duhenglucky
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add lockMQ function for support order message
上级
41d5adc0
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
88 addition
and
52 deletion
+88
-52
broker/src/main/java/org/apache/rocketmq/broker/processor/AdminBrokerProcessor.java
...pache/rocketmq/broker/processor/AdminBrokerProcessor.java
+9
-10
snode/src/main/java/org/apache/rocketmq/snode/SnodeController.java
.../main/java/org/apache/rocketmq/snode/SnodeController.java
+14
-32
snode/src/main/java/org/apache/rocketmq/snode/constant/SnodeConstant.java
...ava/org/apache/rocketmq/snode/constant/SnodeConstant.java
+2
-0
snode/src/main/java/org/apache/rocketmq/snode/processor/ConsumerManageProcessor.java
...che/rocketmq/snode/processor/ConsumerManageProcessor.java
+16
-0
snode/src/main/java/org/apache/rocketmq/snode/service/EnodeService.java
.../java/org/apache/rocketmq/snode/service/EnodeService.java
+6
-0
snode/src/main/java/org/apache/rocketmq/snode/service/impl/LocalEnodeServiceImpl.java
...he/rocketmq/snode/service/impl/LocalEnodeServiceImpl.java
+15
-8
snode/src/main/java/org/apache/rocketmq/snode/service/impl/RemoteEnodeServiceImpl.java
...e/rocketmq/snode/service/impl/RemoteEnodeServiceImpl.java
+20
-0
snode/src/main/java/org/apache/rocketmq/snode/service/impl/ScheduledServiceImpl.java
...che/rocketmq/snode/service/impl/ScheduledServiceImpl.java
+6
-2
未找到文件。
broker/src/main/java/org/apache/rocketmq/broker/processor/AdminBrokerProcessor.java
浏览文件 @
3706778b
...
...
@@ -43,8 +43,6 @@ import org.apache.rocketmq.common.admin.OffsetWrapper;
import
org.apache.rocketmq.common.admin.TopicOffset
;
import
org.apache.rocketmq.common.admin.TopicStatsTable
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.common.message.MessageDecoder
;
import
org.apache.rocketmq.common.message.MessageId
;
import
org.apache.rocketmq.common.message.MessageQueue
;
...
...
@@ -102,14 +100,16 @@ import org.apache.rocketmq.common.stats.StatsItem;
import
org.apache.rocketmq.common.stats.StatsSnapshot
;
import
org.apache.rocketmq.common.subscription.SubscriptionGroupConfig
;
import
org.apache.rocketmq.filter.util.BitsArray
;
import
org.apache.rocketmq.logging.InternalLogger
;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.RequestProcessor
;
import
org.apache.rocketmq.remoting.common.RemotingHelper
;
import
org.apache.rocketmq.remoting.exception.RemotingCommandException
;
import
org.apache.rocketmq.remoting.exception.RemotingTimeoutException
;
import
org.apache.rocketmq.remoting.RequestProcessor
;
import
org.apache.rocketmq.remoting.netty.NettyChannelHandlerContextImpl
;
import
org.apache.rocketmq.remoting.serialize.LanguageCode
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.serialize.LanguageCode
;
import
org.apache.rocketmq.remoting.serialize.RemotingSerializable
;
import
org.apache.rocketmq.store.ConsumeQueue
;
import
org.apache.rocketmq.store.ConsumeQueueExt
;
...
...
@@ -129,7 +129,7 @@ public class AdminBrokerProcessor implements RequestProcessor {
@Override
public
RemotingCommand
processRequest
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
throws
RemotingCommandException
{
NettyChannelHandlerContextImpl
nettyChannelHandlerContext
=
(
NettyChannelHandlerContextImpl
)
remotingChannel
;
NettyChannelHandlerContextImpl
nettyChannelHandlerContext
=
(
NettyChannelHandlerContextImpl
)
remotingChannel
;
ChannelHandlerContext
ctx
=
nettyChannelHandlerContext
.
getChannelHandlerContext
();
switch
(
request
.
getCode
())
{
case
RequestCode
.
UPDATE_AND_CREATE_TOPIC
:
...
...
@@ -250,7 +250,7 @@ public class AdminBrokerProcessor implements RequestProcessor {
this
.
brokerController
.
getTopicConfigManager
().
updateTopicConfig
(
topicConfig
);
this
.
brokerController
.
registerIncrementBrokerData
(
topicConfig
,
this
.
brokerController
.
getTopicConfigManager
().
getDataVersion
());
this
.
brokerController
.
registerIncrementBrokerData
(
topicConfig
,
this
.
brokerController
.
getTopicConfigManager
().
getDataVersion
());
return
null
;
}
...
...
@@ -440,11 +440,10 @@ public class AdminBrokerProcessor implements RequestProcessor {
return
response
;
}
p
rivate
RemotingCommand
lockBatchMQ
(
ChannelHandlerContext
ctx
,
RemotingCommand
request
)
throws
RemotingCommandException
{
p
ublic
RemotingCommand
lockBatchMQ
(
ChannelHandlerContext
ctx
,
RemotingCommand
request
)
{
final
RemotingCommand
response
=
RemotingCommand
.
createResponseCommand
(
null
);
LockBatchRequestBody
requestBody
=
LockBatchRequestBody
.
decode
(
request
.
getBody
(),
LockBatchRequestBody
.
class
);
Set
<
MessageQueue
>
lockOKMQSet
=
this
.
brokerController
.
getRebalanceLockManager
().
tryLockBatch
(
requestBody
.
getConsumerGroup
(),
requestBody
.
getMqSet
(),
...
...
@@ -459,7 +458,7 @@ public class AdminBrokerProcessor implements RequestProcessor {
return
response
;
}
p
rivate
RemotingCommand
unlockBatchMQ
(
ChannelHandlerContext
ctx
,
p
ublic
RemotingCommand
unlockBatchMQ
(
ChannelHandlerContext
ctx
,
RemotingCommand
request
)
throws
RemotingCommandException
{
final
RemotingCommand
response
=
RemotingCommand
.
createResponseCommand
(
null
);
UnlockBatchRequestBody
requestBody
=
UnlockBatchRequestBody
.
decode
(
request
.
getBody
(),
UnlockBatchRequestBody
.
class
);
...
...
snode/src/main/java/org/apache/rocketmq/snode/SnodeController.java
浏览文件 @
3706778b
...
...
@@ -313,38 +313,20 @@ public class SnodeController {
}
public
void
registerProcessor
()
{
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
SEND_MESSAGE_V2
,
sendMessageProcessor
,
this
.
sendMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
CONSUMER_SEND_MSG_BACK
,
sendMessageProcessor
,
this
.
sendMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
HEART_BEAT
,
heartbeatProcessor
,
this
.
heartbeatExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
UNREGISTER_CLIENT
,
heartbeatProcessor
,
this
.
heartbeatExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
CHECK_CLIENT_CONFIG
,
heartbeatProcessor
,
this
.
heartbeatExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
SNODE_PULL_MESSAGE
,
pullMessageProcessor
,
this
.
pullMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
GET_CONSUMER_LIST_BY_GROUP
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
UPDATE_CONSUMER_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
QUERY_CONSUMER_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
GET_MIN_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
GET_MAX_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
SEARCH_OFFSET_BY_TIMESTAMP
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
CREATE_RETRY_TOPIC
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
mqttRemotingServer
.
registerProcessor
(
RequestCode
.
MQTT_MESSAGE
,
defaultMqttMessageProcessor
,
handleMqttMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
SEND_MESSAGE_V2
,
sendMessageProcessor
,
this
.
sendMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
CONSUMER_SEND_MSG_BACK
,
sendMessageProcessor
,
this
.
sendMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
HEART_BEAT
,
heartbeatProcessor
,
this
.
heartbeatExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
UNREGISTER_CLIENT
,
heartbeatProcessor
,
this
.
heartbeatExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
CHECK_CLIENT_CONFIG
,
heartbeatProcessor
,
this
.
heartbeatExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
PULL_MESSAGE
,
pullMessageProcessor
,
this
.
pullMessageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
GET_CONSUMER_LIST_BY_GROUP
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
UPDATE_CONSUMER_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
QUERY_CONSUMER_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
GET_MIN_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
GET_MAX_OFFSET
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
SEARCH_OFFSET_BY_TIMESTAMP
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
snodeServer
.
registerProcessor
(
RequestCode
.
CREATE_RETRY_TOPIC
,
consumerManageProcessor
,
this
.
consumerManageExecutor
);
this
.
mqttRemotingServer
.
registerProcessor
(
RequestCode
.
MQTT_MESSAGE
,
defaultMqttMessageProcessor
,
handleMqttMessageExecutor
);
}
...
...
snode/src/main/java/org/apache/rocketmq/snode/constant/SnodeConstant.java
浏览文件 @
3706778b
...
...
@@ -32,4 +32,6 @@ public class SnodeConstant {
public
static
final
AttributeKey
<
ClientRole
>
NETTY_CLIENT_ROLE_ATTRIBUTE_KEY
=
AttributeKey
.
valueOf
(
"netty.client.role"
);
public
static
final
AttributeKey
<
Client
>
NETTY_CLIENT_ATTRIBUTE_KEY
=
AttributeKey
.
valueOf
(
"netty.client"
);
public
static
final
String
ENODE_NAME
=
"enodeName"
;
}
snode/src/main/java/org/apache/rocketmq/snode/processor/ConsumerManageProcessor.java
浏览文件 @
3706778b
...
...
@@ -74,6 +74,10 @@ public class ConsumerManageProcessor implements RequestProcessor {
return
getMinOffset
(
remotingChannel
,
request
);
case
RequestCode
.
CREATE_RETRY_TOPIC
:
return
createRetryTopic
(
remotingChannel
,
request
);
case
RequestCode
.
LOCK_BATCH_MQ
:
return
lockBatchMQ
(
remotingChannel
,
request
);
case
RequestCode
.
UNLOCK_BATCH_MQ
:
return
unlockBatchMQ
(
remotingChannel
,
request
);
default
:
break
;
}
...
...
@@ -214,5 +218,17 @@ public class ConsumerManageProcessor implements RequestProcessor {
requestHeader
.
getEnodeName
();
return
this
.
snodeController
.
getEnodeService
().
creatRetryTopic
(
remotingChannel
,
requestHeader
.
getEnodeName
(),
request
);
}
public
RemotingCommand
lockBatchMQ
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
{
return
this
.
snodeController
.
getEnodeService
().
lockBatchMQ
(
remotingChannel
,
request
);
}
public
RemotingCommand
unlockBatchMQ
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
{
return
this
.
snodeController
.
getEnodeService
().
unlockBatchMQ
(
remotingChannel
,
request
);
}
}
snode/src/main/java/org/apache/rocketmq/snode/service/EnodeService.java
浏览文件 @
3706778b
...
...
@@ -121,4 +121,10 @@ public interface EnodeService {
long
timestamp
,
RemotingCommand
request
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
,
RemotingCommandException
;
RemotingCommand
lockBatchMQ
(
final
RemotingChannel
remotingChannel
,
final
RemotingCommand
remotingCommand
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
;
RemotingCommand
unlockBatchMQ
(
final
RemotingChannel
remotingChannel
,
final
RemotingCommand
remotingCommand
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
;
}
snode/src/main/java/org/apache/rocketmq/snode/service/impl/LocalEnodeServiceImpl.java
浏览文件 @
3706778b
...
...
@@ -16,6 +16,7 @@
*/
package
org.apache.rocketmq.snode.service.impl
;
import
io.netty.channel.ChannelHandlerContext
;
import
java.util.concurrent.CompletableFuture
;
import
org.apache.rocketmq.broker.BrokerController
;
import
org.apache.rocketmq.common.constant.LoggerName
;
...
...
@@ -24,6 +25,7 @@ import org.apache.rocketmq.logging.InternalLogger;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.remoting.RemotingChannel
;
import
org.apache.rocketmq.remoting.netty.CodecHelper
;
import
org.apache.rocketmq.remoting.netty.NettyChannelHandlerContextImpl
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.snode.service.EnodeService
;
...
...
@@ -100,14 +102,6 @@ public class LocalEnodeServiceImpl implements EnodeService {
public
void
persistOffset
(
RemotingChannel
remotingChannel
,
String
enodeName
,
String
groupName
,
String
topic
,
int
queueId
,
long
offset
)
{
try
{
// UpdateConsumerOffsetRequestHeader requestHeader = new UpdateConsumerOffsetRequestHeader();
// requestHeader.setConsumerGroup(groupName);
// requestHeader.setTopic(topic);
// requestHeader.setQueueId(queueId);
// requestHeader.setCommitOffset(offset);
// RemotingCommand request = RemotingCommand.createRequestCommand(RequestCode.UPDATE_CONSUMER_OFFSET, requestHeader);
// this.brokerController.getConsumerManageProcessor().processRequest(remotingChannel, request);
this
.
brokerController
.
getConsumerOffsetManager
().
commitOffset
(
remotingChannel
.
remoteAddress
().
toString
(),
groupName
,
topic
,
queueId
,
offset
);
}
catch
(
Exception
ex
)
{
...
...
@@ -135,4 +129,17 @@ public class LocalEnodeServiceImpl implements EnodeService {
String
topic
,
int
queueId
,
long
timestamp
,
RemotingCommand
request
)
{
return
this
.
brokerController
.
getMessageStore
().
getOffsetInQueueByTime
(
topic
,
queueId
,
timestamp
);
}
@Override
public
RemotingCommand
lockBatchMQ
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
{
NettyChannelHandlerContextImpl
nettyChannelHandlerContext
=
(
NettyChannelHandlerContextImpl
)
remotingChannel
;
ChannelHandlerContext
ctx
=
nettyChannelHandlerContext
.
getChannelHandlerContext
();
return
this
.
brokerController
.
getAdminProcessor
().
lockBatchMQ
(
ctx
,
request
);
}
@Override
public
RemotingCommand
unlockBatchMQ
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
{
NettyChannelHandlerContextImpl
nettyChannelHandlerContext
=
(
NettyChannelHandlerContextImpl
)
remotingChannel
;
ChannelHandlerContext
ctx
=
nettyChannelHandlerContext
.
getChannelHandlerContext
();
log
.
info
(
"un"
);
return
this
.
brokerController
.
getAdminProcessor
().
lockBatchMQ
(
ctx
,
request
);
}
}
snode/src/main/java/org/apache/rocketmq/snode/service/impl/RemoteEnodeServiceImpl.java
浏览文件 @
3706778b
...
...
@@ -263,4 +263,24 @@ public class RemoteEnodeServiceImpl implements EnodeService {
return
this
.
snodeController
.
getRemotingClient
().
invokeSync
(
address
,
request
,
SnodeConstant
.
DEFAULT_TIMEOUT_MILLS
);
}
@Override
public
RemotingCommand
lockBatchMQ
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
{
return
transferToEnode
(
request
);
}
@Override
public
RemotingCommand
unlockBatchMQ
(
RemotingChannel
remotingChannel
,
RemotingCommand
request
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
{
return
transferToEnode
(
request
);
}
private
RemotingCommand
transferToEnode
(
final
RemotingCommand
request
)
throws
InterruptedException
,
RemotingTimeoutException
,
RemotingSendRequestException
,
RemotingConnectException
{
String
enodeName
=
request
.
getExtFields
().
get
(
SnodeConstant
.
ENODE_NAME
);
String
address
=
this
.
snodeController
.
getNnodeService
().
getAddressByEnodeName
(
enodeName
,
false
);
return
this
.
snodeController
.
getRemotingClient
().
invokeSync
(
address
,
request
,
SnodeConstant
.
DEFAULT_TIMEOUT_MILLS
);
}
}
snode/src/main/java/org/apache/rocketmq/snode/service/impl/ScheduledServiceImpl.java
浏览文件 @
3706778b
...
...
@@ -101,7 +101,9 @@ public class ScheduledServiceImpl implements ScheduledService {
@Override
public
void
run
()
{
try
{
snodeController
.
getEnodeService
().
updateEnodeAddress
(
snodeConfig
.
getClusterName
());
if
(!
snodeController
.
getSnodeConfig
().
isEmbeddedModeEnable
())
{
snodeController
.
getEnodeService
().
updateEnodeAddress
(
snodeConfig
.
getClusterName
());
}
}
catch
(
Exception
ex
)
{
log
.
warn
(
"Update broker addr error:{}"
,
ex
);
}
...
...
@@ -123,7 +125,9 @@ public class ScheduledServiceImpl implements ScheduledService {
@Override
public
void
run
()
{
try
{
snodeController
.
getNnodeService
().
updateEnodeClusterInfo
();
if
(!
snodeController
.
getSnodeConfig
().
isEmbeddedModeEnable
())
{
snodeController
.
getNnodeService
().
updateEnodeClusterInfo
();
}
}
catch
(
Exception
ex
)
{
log
.
warn
(
"Update broker addr error:{}"
,
ex
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录