Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Kwan的解忧杂货铺@新空间代码工作室
Rocketmq
提交
12915b80
R
Rocketmq
项目概览
Kwan的解忧杂货铺@新空间代码工作室
/
Rocketmq
与 Fork 源项目一致
Fork自
Apache RocketMQ / Rocketmq
通知
1
Star
0
Fork
0
代码
文件
提交
分支
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看板
提交
12915b80
编写于
12月 06, 2021
作者:
D
dongeforever
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add clean item logic for topic queue mapping
上级
527382e4
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
150 addition
and
3 deletion
+150
-3
broker/src/main/java/org/apache/rocketmq/broker/BrokerController.java
...ain/java/org/apache/rocketmq/broker/BrokerController.java
+25
-0
broker/src/main/java/org/apache/rocketmq/broker/topic/TopicQueueMappingManager.java
...pache/rocketmq/broker/topic/TopicQueueMappingManager.java
+90
-0
common/src/main/java/org/apache/rocketmq/common/admin/TopicOffset.java
...in/java/org/apache/rocketmq/common/admin/TopicOffset.java
+9
-0
common/src/main/java/org/apache/rocketmq/common/protocol/header/GetTopicStatsInfoRequestHeader.java
...ommon/protocol/header/GetTopicStatsInfoRequestHeader.java
+2
-1
common/src/main/java/org/apache/rocketmq/common/rpc/RpcClientImpl.java
...in/java/org/apache/rocketmq/common/rpc/RpcClientImpl.java
+23
-1
common/src/main/java/org/apache/rocketmq/common/rpc/RpcResponse.java
...main/java/org/apache/rocketmq/common/rpc/RpcResponse.java
+1
-1
未找到文件。
broker/src/main/java/org/apache/rocketmq/broker/BrokerController.java
浏览文件 @
12915b80
...
...
@@ -163,6 +163,9 @@ public class BrokerController {
private
final
BrokerOuterAPI
brokerOuterAPI
;
private
final
ScheduledExecutorService
scheduledExecutorService
=
Executors
.
newSingleThreadScheduledExecutor
(
new
ThreadFactoryImpl
(
"BrokerControllerScheduledThread"
));
//the topic queue mapping is costly, so use an independent executor
private
final
ScheduledExecutorService
scheduledForTopicQueueMapping
=
Executors
.
newSingleThreadScheduledExecutor
(
new
ThreadFactoryImpl
(
"BrokerControllerScheduledThread-TopicQueueMapping"
));
private
final
SlaveSynchronize
slaveSynchronize
;
private
final
BlockingQueue
<
Runnable
>
sendThreadPoolQueue
;
private
final
BlockingQueue
<
Runnable
>
ackThreadPoolQueue
;
...
...
@@ -498,6 +501,22 @@ public class BrokerController {
}
},
1
,
5
,
TimeUnit
.
SECONDS
);
this
.
scheduledForTopicQueueMapping
.
scheduleAtFixedRate
(
()
->
{
try
{
this
.
topicQueueMappingManager
.
cleanItemListMoreThanSecondGen
();
}
catch
(
Throwable
t
)
{
log
.
error
(
"ScheduledTask cleanItemListMoreThanSecondGen failed"
,
t
);
}
},
1
,
5
,
TimeUnit
.
MINUTES
);
this
.
scheduledForTopicQueueMapping
.
scheduleAtFixedRate
(
()
->
{
try
{
this
.
topicQueueMappingManager
.
cleanItemExpired
();
}
catch
(
Throwable
t
)
{
log
.
error
(
"ScheduledTask cleanItemExpired failed"
,
t
);
}
},
1
,
5
,
TimeUnit
.
MINUTES
);
if
(!
messageStoreConfig
.
isEnableDLegerCommitLog
())
{
if
(
BrokerRole
.
SLAVE
==
this
.
messageStoreConfig
.
getBrokerRole
())
{
if
(
this
.
messageStoreConfig
.
getHaMasterAddress
()
!=
null
&&
this
.
messageStoreConfig
.
getHaMasterAddress
().
length
()
>=
6
)
{
...
...
@@ -892,6 +911,12 @@ public class BrokerController {
}
catch
(
InterruptedException
e
)
{
}
this
.
scheduledForTopicQueueMapping
.
shutdown
();
try
{
this
.
scheduledForTopicQueueMapping
.
awaitTermination
(
5000
,
TimeUnit
.
MILLISECONDS
);
}
catch
(
Throwable
ignored
)
{
}
this
.
unregisterBrokerAll
();
if
(
this
.
sendMessageExecutor
!=
null
)
{
...
...
broker/src/main/java/org/apache/rocketmq/broker/topic/TopicQueueMappingManager.java
浏览文件 @
12915b80
...
...
@@ -21,6 +21,14 @@ import org.apache.rocketmq.broker.BrokerController;
import
org.apache.rocketmq.broker.BrokerPathConfigHelper
;
import
org.apache.rocketmq.common.ConfigManager
;
import
org.apache.rocketmq.common.DataVersion
;
import
org.apache.rocketmq.common.UtilAll
;
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.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.TopicQueueMappingContext
;
import
org.apache.rocketmq.common.constant.LoggerName
;
...
...
@@ -32,10 +40,14 @@ import org.apache.rocketmq.logging.InternalLogger;
import
org.apache.rocketmq.logging.InternalLoggerFactory
;
import
org.apache.rocketmq.common.rpc.TopicQueueRequestHeader
;
import
org.apache.rocketmq.remoting.protocol.RemotingCommand
;
import
org.apache.rocketmq.store.DefaultMessageStore
;
import
java.util.HashMap
;
import
java.util.HashSet
;
import
java.util.Iterator
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.Set
;
import
java.util.concurrent.ConcurrentHashMap
;
import
java.util.concurrent.ConcurrentMap
;
import
java.util.concurrent.TimeUnit
;
...
...
@@ -272,4 +284,82 @@ public class TopicQueueMappingManager extends ConfigManager {
}
}
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
())
{
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
;
}
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
())
{
boolean
result
=
items
.
remove
(
earlistItem
);
changed
=
changed
||
result
;
log
.
info
(
"The logic queue item {} is removed {} because of {}"
,
result
,
earlistItem
,
topicOffset
);
}
}
UtilAll
.
sleep
(
10
);
}
}
catch
(
Throwable
t
)
{
log
.
error
(
"Try cleanItemExpired failed"
,
t
);
}
finally
{
if
(
changed
)
{
this
.
dataVersion
.
nextVersion
();
this
.
persist
();
log
.
info
(
"CleanItemExpired changed"
);
}
log
.
info
(
"cleanItemExpired cost {} ms"
,
System
.
currentTimeMillis
()
-
start
);
}
}
}
common/src/main/java/org/apache/rocketmq/common/admin/TopicOffset.java
浏览文件 @
12915b80
...
...
@@ -44,4 +44,13 @@ public class TopicOffset {
public
void
setLastUpdateTimestamp
(
long
lastUpdateTimestamp
)
{
this
.
lastUpdateTimestamp
=
lastUpdateTimestamp
;
}
@Override
public
String
toString
()
{
return
"TopicOffset{"
+
"minOffset="
+
minOffset
+
", maxOffset="
+
maxOffset
+
", lastUpdateTimestamp="
+
lastUpdateTimestamp
+
'}'
;
}
}
common/src/main/java/org/apache/rocketmq/common/protocol/header/GetTopicStatsInfoRequestHeader.java
浏览文件 @
12915b80
...
...
@@ -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
GetTopicStatsInfoRequestHeader
implements
CommandCustom
Header
{
public
class
GetTopicStatsInfoRequestHeader
extends
RpcRequest
Header
{
@CFNotNull
private
String
topic
;
...
...
common/src/main/java/org/apache/rocketmq/common/rpc/RpcClientImpl.java
浏览文件 @
12915b80
package
org.apache.rocketmq.common.rpc
;
import
com.alibaba.fastjson.JSON
;
import
io.netty.util.concurrent.ImmediateEventExecutor
;
import
io.netty.util.concurrent.Promise
;
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.ResponseCode
;
...
...
@@ -83,6 +83,9 @@ public class RpcClientImpl implements RpcClient {
case
RequestCode
.
QUERY_CONSUMER_OFFSET
:
rpcResponsePromise
=
handleQueryConsumerOffset
(
addr
,
request
,
timeoutMs
);
break
;
case
RequestCode
.
GET_TOPIC_STATS_INFO
:
rpcResponsePromise
=
handleGetTopicStats
(
addr
,
request
,
timeoutMs
);
break
;
default
:
throw
new
RpcException
(
ResponseCode
.
REQUEST_CODE_NOT_SUPPORTED
,
"Unknown request code "
+
request
.
getCode
());
}
...
...
@@ -209,6 +212,25 @@ public class RpcClientImpl implements RpcClient {
return
rpcResponsePromise
;
}
public
Promise
<
RpcResponse
>
handleGetTopicStats
(
String
addr
,
RpcRequest
rpcRequest
,
long
timeoutMillis
)
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
));
break
;
}
default
:{
rpcResponsePromise
.
setSuccess
(
new
RpcResponse
(
new
RpcException
(
responseCommand
.
getCode
(),
"unknown remote error"
)));
}
}
return
rpcResponsePromise
;
}
public
Promise
<
RpcResponse
>
handleGetMinOffset
(
String
addr
,
RpcRequest
rpcRequest
,
long
timeoutMillis
)
throws
Exception
{
final
Promise
<
RpcResponse
>
rpcResponsePromise
=
createResponseFuture
();
...
...
common/src/main/java/org/apache/rocketmq/common/rpc/RpcResponse.java
浏览文件 @
12915b80
...
...
@@ -28,7 +28,7 @@ public class RpcResponse {
}
public
RpcResponse
(
int
code
,
CommandCustomHeader
header
,
byte
[]
body
)
{
public
RpcResponse
(
int
code
,
CommandCustomHeader
header
,
Object
body
)
{
this
.
code
=
code
;
this
.
header
=
header
;
this
.
body
=
body
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录