Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
c06564f6
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看板
提交
c06564f6
编写于
12月 06, 2021
作者:
D
dongeforever
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Try polishing the clear logic, need more polishment
上级
9cae8c1b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
121 addition
and
61 deletion
+121
-61
broker/src/main/java/org/apache/rocketmq/broker/topic/TopicQueueMappingManager.java
...pache/rocketmq/broker/topic/TopicQueueMappingManager.java
+106
-55
common/src/main/java/org/apache/rocketmq/common/protocol/header/GetTopicConfigRequestHeader.java
...q/common/protocol/header/GetTopicConfigRequestHeader.java
+2
-1
common/src/main/java/org/apache/rocketmq/common/rpc/RpcClientImpl.java
...in/java/org/apache/rocketmq/common/rpc/RpcClientImpl.java
+13
-5
未找到文件。
broker/src/main/java/org/apache/rocketmq/broker/topic/TopicQueueMappingManager.java
浏览文件 @
c06564f6
...
...
@@ -26,10 +26,12 @@ import org.apache.rocketmq.common.admin.TopicOffset;
import
org.apache.rocketmq.common.admin.TopicStatsTable
;
import
org.apache.rocketmq.common.message.MessageQueue
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
import
org.apache.rocketmq.common.protocol.header.GetTopicConfigRequestHeader
;
import
org.apache.rocketmq.common.protocol.header.GetTopicStatsInfoRequestHeader
;
import
org.apache.rocketmq.common.rpc.RpcRequest
;
import
org.apache.rocketmq.common.rpc.RpcResponse
;
import
org.apache.rocketmq.common.statictopic.LogicQueueMappingItem
;
import
org.apache.rocketmq.common.statictopic.TopicConfigAndQueueMapping
;
import
org.apache.rocketmq.common.statictopic.TopicQueueMappingContext
;
import
org.apache.rocketmq.common.constant.LoggerName
;
import
org.apache.rocketmq.common.protocol.ResponseCode
;
...
...
@@ -258,45 +260,13 @@ public class TopicQueueMappingManager extends ConfigManager {
public
void
cleanItemListMoreThanSecondGen
()
{
for
(
String
topic
:
topicQueueMappingTable
.
keySet
())
{
TopicQueueMappingDetail
mappingDetail
=
topicQueueMappingTable
.
get
(
topic
);
if
(
mappingDetail
==
null
||
mappingDetail
.
getHostedQueues
().
isEmpty
())
{
continue
;
}
if
(!
mappingDetail
.
getBname
().
equals
(
this
.
brokerController
.
getBrokerConfig
().
getBrokerName
()))
{
log
.
warn
(
"The TopicQueueMappingDetail [{}] should not exist in this broker"
,
mappingDetail
);
continue
;
}
Iterator
<
Map
.
Entry
<
Integer
,
List
<
LogicQueueMappingItem
>>>
it
=
mappingDetail
.
getHostedQueues
().
entrySet
().
iterator
();
while
(
it
.
hasNext
())
{
Map
.
Entry
<
Integer
,
List
<
LogicQueueMappingItem
>>
entry
=
it
.
next
();
Integer
queueId
=
entry
.
getKey
();
List
<
LogicQueueMappingItem
>
items
=
entry
.
getValue
();
if
(
items
.
size
()
<=
2
)
{
continue
;
}
LogicQueueMappingItem
leaderItem
=
items
.
get
(
items
.
size
()
-
1
);
LogicQueueMappingItem
secLeaderItem
=
items
.
get
(
items
.
size
()
-
2
);
if
(!
leaderItem
.
getBname
().
equals
(
mappingDetail
.
getBname
())
&&
!
secLeaderItem
.
getBname
().
equals
(
mappingDetail
.
getBname
()))
{
it
.
remove
();
log
.
info
(
"The topic queue {} {} is expired with items {}"
,
mappingDetail
.
getTopic
(),
queueId
,
items
);
}
}
}
}
public
void
cleanItemExpired
()
{
String
when
=
this
.
brokerController
.
getMessageStoreConfig
().
getDeleteWhen
();
if
(!
UtilAll
.
isItTimeToDo
(
when
))
{
return
;
}
boolean
changed
=
false
;
long
start
=
System
.
currentTimeMillis
();
try
{
for
(
String
topic
:
topicQueueMappingTable
.
keySet
())
{
for
(
String
topic
:
topicQueueMappingTable
.
keySet
())
{
try
{
TopicQueueMappingDetail
mappingDetail
=
topicQueueMappingTable
.
get
(
topic
);
if
(
mappingDetail
==
null
||
mappingDetail
.
getHostedQueues
().
isEmpty
())
{
...
...
@@ -307,51 +277,132 @@ public class TopicQueueMappingManager extends ConfigManager {
continue
;
}
Set
<
String
>
brokers
=
new
HashSet
<>();
for
(
List
<
LogicQueueMappingItem
>
items:
mappingDetail
.
getHostedQueues
().
values
())
{
for
(
List
<
LogicQueueMappingItem
>
items
:
mappingDetail
.
getHostedQueues
().
values
())
{
if
(
items
.
size
()
<
2
)
{
continue
;
}
LogicQueueMappingItem
earlistItem
=
items
.
get
(
0
);
brokers
.
add
(
earlistItem
.
getBname
());
LogicQueueMappingItem
leaderItem
=
items
.
get
(
items
.
size
()
-
1
);
if
(!
leaderItem
.
equals
(
mappingDetail
.
getBname
()))
{
brokers
.
add
(
leaderItem
.
getBname
());
}
}
Map
<
String
,
TopicStatsTable
>
statsTable
=
new
HashMap
<>();
if
(
brokers
.
isEmpty
())
{
continue
;
}
Map
<
String
,
TopicConfigAndQueueMapping
>
configAndQueueMappingMap
=
new
HashMap
<>();
for
(
String
broker:
brokers
)
{
GetTopic
StatsInfoRequestHeader
header
=
new
GetTopicStatsInfo
RequestHeader
();
GetTopic
ConfigRequestHeader
header
=
new
GetTopicConfig
RequestHeader
();
header
.
setTopic
(
topic
);
header
.
setBname
(
broker
);
try
{
RpcRequest
rpcRequest
=
new
RpcRequest
(
RequestCode
.
GET_TOPIC_
STATS_INFO
,
header
,
null
);
RpcRequest
rpcRequest
=
new
RpcRequest
(
RequestCode
.
GET_TOPIC_
CONFIG
,
header
,
null
);
RpcResponse
rpcResponse
=
this
.
brokerController
.
getBrokerOuterAPI
().
getRpcClient
().
invoke
(
rpcRequest
,
this
.
brokerController
.
getBrokerConfig
().
getForwardTimeout
()).
get
();
if
(
rpcResponse
.
getException
()
!=
null
)
{
throw
rpcResponse
.
getException
();
}
statsTable
.
put
(
broker
,
(
TopicStatsTable
)
rpcResponse
.
getBody
());
configAndQueueMappingMap
.
put
(
broker
,
(
TopicConfigAndQueueMapping
)
rpcResponse
.
getBody
());
}
catch
(
Throwable
rt
)
{
log
.
warn
(
"Get remote topic {} state info failed from broker {}"
,
topic
,
broker
,
rt
);
}
}
for
(
List
<
LogicQueueMappingItem
>
items:
mappingDetail
.
getHostedQueues
().
values
())
{
Iterator
<
Map
.
Entry
<
Integer
,
List
<
LogicQueueMappingItem
>>>
it
=
mappingDetail
.
getHostedQueues
().
entrySet
().
iterator
();
while
(
it
.
hasNext
())
{
Map
.
Entry
<
Integer
,
List
<
LogicQueueMappingItem
>>
entry
=
it
.
next
();
Integer
queueId
=
entry
.
getKey
();
List
<
LogicQueueMappingItem
>
items
=
entry
.
getValue
();
if
(
items
.
size
()
<
2
)
{
continue
;
}
LogicQueueMappingItem
earlistItem
=
items
.
get
(
0
);
TopicStatsTable
topicStats
=
statsTable
.
get
(
earlistItem
.
getBname
());
if
(
topicStats
==
null
)
{
LogicQueueMappingItem
leaderItem
=
items
.
get
(
items
.
size
()
-
1
);
TopicConfigAndQueueMapping
configAndQueueMapping
=
configAndQueueMappingMap
.
get
(
leaderItem
.
getBname
());
if
(
configAndQueueMapping
==
null
)
{
continue
;
}
TopicOffset
topicOffset
=
topicStats
.
getOffsetTable
().
get
(
new
MessageQueue
(
topic
,
earlistItem
.
getBname
(),
earlistItem
.
getQueueId
()));
if
(
topicOffset
==
null
)
{
//this may should not happen
log
.
warn
(
"Get null topicOffset for {}"
,
earlistItem
);
List
<
LogicQueueMappingItem
>
itemsRemote
=
configAndQueueMapping
.
getMappingDetail
().
getHostedQueues
().
get
(
queueId
);
//TODO
}
}
catch
(
Throwable
tt
)
{
log
.
error
(
"Try cleanItemListMoreThanSecondGen failed for topic {}"
,
topic
,
tt
);
}
finally
{
UtilAll
.
sleep
(
10
);
}
}
}
public
void
cleanItemExpired
()
{
String
when
=
this
.
brokerController
.
getMessageStoreConfig
().
getDeleteWhen
();
if
(!
UtilAll
.
isItTimeToDo
(
when
))
{
return
;
}
boolean
changed
=
false
;
long
start
=
System
.
currentTimeMillis
();
try
{
for
(
String
topic
:
topicQueueMappingTable
.
keySet
())
{
try
{
TopicQueueMappingDetail
mappingDetail
=
topicQueueMappingTable
.
get
(
topic
);
if
(
mappingDetail
==
null
||
mappingDetail
.
getHostedQueues
().
isEmpty
())
{
continue
;
}
if
(!
mappingDetail
.
getBname
().
equals
(
this
.
brokerController
.
getBrokerConfig
().
getBrokerName
()))
{
log
.
warn
(
"The TopicQueueMappingDetail [{}] should not exist in this broker"
,
mappingDetail
);
continue
;
}
if
(
topicOffset
.
getMaxOffset
()
==
topicOffset
.
getMinOffset
())
{
boolean
result
=
items
.
remove
(
earlistItem
);
changed
=
changed
||
result
;
log
.
info
(
"The logic queue item {} is removed {} because of {}"
,
result
,
earlistItem
,
topicOffset
);
Set
<
String
>
brokers
=
new
HashSet
<>();
for
(
List
<
LogicQueueMappingItem
>
items:
mappingDetail
.
getHostedQueues
().
values
())
{
if
(
items
.
size
()
<
2
)
{
continue
;
}
LogicQueueMappingItem
earlistItem
=
items
.
get
(
0
);
brokers
.
add
(
earlistItem
.
getBname
());
}
Map
<
String
,
TopicStatsTable
>
statsTable
=
new
HashMap
<>();
for
(
String
broker:
brokers
)
{
GetTopicStatsInfoRequestHeader
header
=
new
GetTopicStatsInfoRequestHeader
();
header
.
setTopic
(
topic
);
header
.
setBname
(
broker
);
try
{
RpcRequest
rpcRequest
=
new
RpcRequest
(
RequestCode
.
GET_TOPIC_STATS_INFO
,
header
,
null
);
RpcResponse
rpcResponse
=
this
.
brokerController
.
getBrokerOuterAPI
().
getRpcClient
().
invoke
(
rpcRequest
,
this
.
brokerController
.
getBrokerConfig
().
getForwardTimeout
()).
get
();
if
(
rpcResponse
.
getException
()
!=
null
)
{
throw
rpcResponse
.
getException
();
}
statsTable
.
put
(
broker
,
(
TopicStatsTable
)
rpcResponse
.
getBody
());
}
catch
(
Throwable
rt
)
{
log
.
warn
(
"Get remote topic {} state info failed from broker {}"
,
topic
,
broker
,
rt
);
}
}
for
(
List
<
LogicQueueMappingItem
>
items:
mappingDetail
.
getHostedQueues
().
values
())
{
if
(
items
.
size
()
<
2
)
{
continue
;
}
LogicQueueMappingItem
earlistItem
=
items
.
get
(
0
);
TopicStatsTable
topicStats
=
statsTable
.
get
(
earlistItem
.
getBname
());
if
(
topicStats
==
null
)
{
continue
;
}
TopicOffset
topicOffset
=
topicStats
.
getOffsetTable
().
get
(
new
MessageQueue
(
topic
,
earlistItem
.
getBname
(),
earlistItem
.
getQueueId
()));
if
(
topicOffset
==
null
)
{
//this may should not happen
log
.
warn
(
"Get null topicOffset for {}"
,
earlistItem
);
continue
;
}
if
(
topicOffset
.
getMaxOffset
()
==
topicOffset
.
getMinOffset
())
{
//TODO be careful of the concurrent problem
//Should use the lock
boolean
result
=
items
.
remove
(
earlistItem
);
changed
=
changed
||
result
;
log
.
info
(
"The logic queue item {} is removed {} because of {}"
,
result
,
earlistItem
,
topicOffset
);
}
}
}
catch
(
Throwable
tt
)
{
log
.
error
(
"Try CleanItemExpired failed for {}"
,
topic
,
tt
);
}
finally
{
UtilAll
.
sleep
(
10
);
}
UtilAll
.
sleep
(
10
);
}
}
catch
(
Throwable
t
)
{
log
.
error
(
"Try cleanItemExpired failed"
,
t
);
...
...
common/src/main/java/org/apache/rocketmq/common/protocol/header/GetTopicConfigRequestHeader.java
浏览文件 @
c06564f6
...
...
@@ -17,11 +17,12 @@
package
org.apache.rocketmq.common.protocol.header
;
import
org.apache.rocketmq.common.rpc.RpcRequestHeader
;
import
org.apache.rocketmq.remoting.CommandCustomHeader
;
import
org.apache.rocketmq.remoting.annotation.CFNotNull
;
import
org.apache.rocketmq.remoting.exception.RemotingCommandException
;
public
class
GetTopicConfigRequestHeader
implements
CommandCustom
Header
{
public
class
GetTopicConfigRequestHeader
extends
RpcRequest
Header
{
@Override
public
void
checkFields
()
throws
RemotingCommandException
{
}
...
...
common/src/main/java/org/apache/rocketmq/common/rpc/RpcClientImpl.java
浏览文件 @
c06564f6
...
...
@@ -2,6 +2,7 @@ package org.apache.rocketmq.common.rpc;
import
io.netty.util.concurrent.ImmediateEventExecutor
;
import
io.netty.util.concurrent.Promise
;
import
org.apache.rocketmq.common.MixAll
;
import
org.apache.rocketmq.common.admin.TopicStatsTable
;
import
org.apache.rocketmq.common.message.MessageQueue
;
import
org.apache.rocketmq.common.protocol.RequestCode
;
...
...
@@ -9,13 +10,19 @@ import org.apache.rocketmq.common.protocol.ResponseCode;
import
org.apache.rocketmq.common.protocol.header.GetEarliestMsgStoretimeResponseHeader
;
import
org.apache.rocketmq.common.protocol.header.GetMaxOffsetResponseHeader
;
import
org.apache.rocketmq.common.protocol.header.GetMinOffsetResponseHeader
;
import
org.apache.rocketmq.common.protocol.header.GetTopicConfigRequestHeader
;
import
org.apache.rocketmq.common.protocol.header.PullMessageResponseHeader
;
import
org.apache.rocketmq.common.protocol.header.QueryConsumerOffsetResponseHeader
;
import
org.apache.rocketmq.common.protocol.header.SearchOffsetResponseHeader
;
import
org.apache.rocketmq.common.statictopic.TopicConfigAndQueueMapping
;
import
org.apache.rocketmq.remoting.InvokeCallback
;
import
org.apache.rocketmq.remoting.RemotingClient
;
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.netty.ResponseFuture
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.remoting.protocol.RemotingSerializable
;
import
java.util.ArrayList
;
import
java.util.List
;
...
...
@@ -84,7 +91,10 @@ public class RpcClientImpl implements RpcClient {
rpcResponsePromise
=
handleQueryConsumerOffset
(
addr
,
request
,
timeoutMs
);
break
;
case
RequestCode
.
GET_TOPIC_STATS_INFO
:
rpcResponsePromise
=
handleGetTopicStats
(
addr
,
request
,
timeoutMs
);
rpcResponsePromise
=
handleCommonBodyRequest
(
addr
,
request
,
timeoutMs
,
TopicStatsTable
.
class
);
break
;
case
RequestCode
.
GET_TOPIC_CONFIG
:
rpcResponsePromise
=
handleCommonBodyRequest
(
addr
,
request
,
timeoutMs
,
TopicConfigAndQueueMapping
.
class
);
break
;
default
:
throw
new
RpcException
(
ResponseCode
.
REQUEST_CODE_NOT_SUPPORTED
,
"Unknown request code "
+
request
.
getCode
());
...
...
@@ -212,16 +222,14 @@ public class RpcClientImpl implements RpcClient {
return
rpcResponsePromise
;
}
public
Promise
<
RpcResponse
>
handle
GetTopicStats
(
String
addr
,
RpcRequest
rpcRequest
,
long
timeoutMilli
s
)
throws
Exception
{
public
Promise
<
RpcResponse
>
handle
CommonBodyRequest
(
final
String
addr
,
RpcRequest
rpcRequest
,
long
timeoutMillis
,
Class
bodyClas
s
)
throws
Exception
{
final
Promise
<
RpcResponse
>
rpcResponsePromise
=
createResponseFuture
();
RemotingCommand
requestCommand
=
RpcClientUtils
.
createCommandForRpcRequest
(
rpcRequest
);
RemotingCommand
responseCommand
=
this
.
remotingClient
.
invokeSync
(
addr
,
requestCommand
,
timeoutMillis
);
assert
responseCommand
!=
null
;
switch
(
responseCommand
.
getCode
())
{
case
ResponseCode
.
SUCCESS
:
{
TopicStatsTable
topicStatsTable
=
TopicStatsTable
.
decode
(
responseCommand
.
getBody
(),
TopicStatsTable
.
class
);
rpcResponsePromise
.
setSuccess
(
new
RpcResponse
(
ResponseCode
.
SUCCESS
,
null
,
topicStatsTable
));
rpcResponsePromise
.
setSuccess
(
new
RpcResponse
(
ResponseCode
.
SUCCESS
,
null
,
RemotingSerializable
.
decode
(
requestCommand
.
getBody
(),
bodyClass
)));
break
;
}
default
:{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录