Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
檀越@新空间
Rocketmq
提交
cbbd6ff0
R
Rocketmq
项目概览
檀越@新空间
/
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看板
提交
cbbd6ff0
编写于
11月 13, 2018
作者:
D
dongeforever
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Polish role change logic
上级
5020f325
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
66 addition
and
36 deletion
+66
-36
broker/src/main/java/org/apache/rocketmq/broker/BrokerController.java
...ain/java/org/apache/rocketmq/broker/BrokerController.java
+10
-3
broker/src/main/java/org/apache/rocketmq/broker/transaction/TransactionalMessageCheckService.java
.../broker/transaction/TransactionalMessageCheckService.java
+5
-3
store/src/main/java/org/apache/rocketmq/store/schedule/ScheduleMessageService.java
...pache/rocketmq/store/schedule/ScheduleMessageService.java
+51
-30
未找到文件。
broker/src/main/java/org/apache/rocketmq/broker/BrokerController.java
浏览文件 @
cbbd6ff0
...
...
@@ -1060,6 +1060,8 @@ public class BrokerController {
}
public
void
changeToSlave
(
int
brokerId
)
{
log
.
info
(
"Begin to change to slave brokerName={} brokerId={}"
,
brokerConfig
.
getBrokerName
(),
brokerId
);
//change the role
brokerConfig
.
setBrokerId
(
brokerId
==
0
?
1
:
brokerId
);
//TO DO check
messageStoreConfig
.
setBrokerRole
(
BrokerRole
.
SLAVE
);
...
...
@@ -1078,6 +1080,7 @@ public class BrokerController {
}
catch
(
Throwable
ignored
)
{
}
log
.
info
(
"Finish to change to slave brokerName={} brokerId={}"
,
brokerConfig
.
getBrokerName
(),
brokerId
);
}
...
...
@@ -1086,11 +1089,10 @@ public class BrokerController {
if
(
role
==
BrokerRole
.
SLAVE
)
{
return
;
}
log
.
info
(
"Begin to change to master brokerName={}"
,
brokerConfig
.
getBrokerName
());
//handle the slave synchronise
handleSlaveSynchronize
(
role
);
//change the role
brokerConfig
.
setBrokerId
(
0
);
//TO DO check
messageStoreConfig
.
setBrokerRole
(
role
);
//handle the scheduled service
this
.
messageStore
.
handleScheduleMessageService
(
role
);
...
...
@@ -1098,11 +1100,16 @@ public class BrokerController {
//handle the transactional service
this
.
startProcessorByHa
();
//if the operations above are totally successful, we change to master
brokerConfig
.
setBrokerId
(
0
);
//TO DO check
messageStoreConfig
.
setBrokerRole
(
role
);
try
{
this
.
registerBrokerAll
(
true
,
true
,
brokerConfig
.
isForceRegister
());
}
catch
(
Throwable
ignored
)
{
}
log
.
info
(
"Finish to change to master brokerName={}"
,
brokerConfig
.
getBrokerName
());
}
private
void
startProcessorByHa
()
{
...
...
broker/src/main/java/org/apache/rocketmq/broker/transaction/TransactionalMessageCheckService.java
浏览文件 @
cbbd6ff0
...
...
@@ -39,7 +39,8 @@ public class TransactionalMessageCheckService extends ServiceThread {
public
void
start
()
{
if
(
started
.
compareAndSet
(
false
,
true
))
{
super
.
start
();
this
.
brokerController
.
getTransactionalMessageService
().
open
();
//no need to do this
//this.brokerController.getTransactionalMessageService().open();
}
}
...
...
@@ -47,8 +48,9 @@ public class TransactionalMessageCheckService extends ServiceThread {
public
void
shutdown
(
boolean
interrupt
)
{
if
(
started
.
compareAndSet
(
true
,
false
))
{
super
.
shutdown
(
interrupt
);
this
.
brokerController
.
getTransactionalMessageService
().
close
();
this
.
brokerController
.
getTransactionalMessageCheckListener
().
shutDown
();
//no need to do this
//this.brokerController.getTransactionalMessageService().close();
//this.brokerController.getTransactionalMessageCheckListener().shutDown();
}
}
...
...
store/src/main/java/org/apache/rocketmq/store/schedule/ScheduleMessageService.java
浏览文件 @
cbbd6ff0
...
...
@@ -19,11 +19,11 @@ package org.apache.rocketmq.store.schedule;
import
java.util.HashMap
;
import
java.util.Iterator
;
import
java.util.Map
;
import
java.util.Map.Entry
;
import
java.util.Timer
;
import
java.util.TimerTask
;
import
java.util.concurrent.ConcurrentHashMap
;
import
java.util.concurrent.ConcurrentMap
;
import
java.util.concurrent.atomic.AtomicBoolean
;
import
org.apache.rocketmq.common.ConfigManager
;
import
org.apache.rocketmq.common.TopicFilterType
;
import
org.apache.rocketmq.common.constant.LoggerName
;
...
...
@@ -38,6 +38,7 @@ import org.apache.rocketmq.store.ConsumeQueue;
import
org.apache.rocketmq.store.ConsumeQueueExt
;
import
org.apache.rocketmq.store.DefaultMessageStore
;
import
org.apache.rocketmq.store.MessageExtBrokerInner
;
import
org.apache.rocketmq.store.MessageStore
;
import
org.apache.rocketmq.store.PutMessageResult
;
import
org.apache.rocketmq.store.PutMessageStatus
;
import
org.apache.rocketmq.store.SelectMappedBufferResult
;
...
...
@@ -56,15 +57,15 @@ public class ScheduleMessageService extends ConfigManager {
private
final
ConcurrentMap
<
Integer
/* level */
,
Long
/* offset */
>
offsetTable
=
new
ConcurrentHashMap
<
Integer
,
Long
>(
32
);
private
final
Timer
timer
=
new
Timer
(
"ScheduleMessageTimerThread"
,
true
);
private
final
DefaultMessageStore
defaultMessageStore
;
private
final
AtomicBoolean
started
=
new
AtomicBoolean
(
false
);
private
Timer
timer
;
private
MessageStore
writeMessageStore
;
private
int
maxDelayLevel
;
public
ScheduleMessageService
(
final
DefaultMessageStore
defaultMessageStore
)
{
this
.
defaultMessageStore
=
defaultMessageStore
;
this
.
writeMessageStore
=
defaultMessageStore
;
}
public
static
int
queueId2DelayLevel
(
final
int
queueId
)
{
...
...
@@ -75,10 +76,18 @@ public class ScheduleMessageService extends ConfigManager {
return
delayLevel
-
1
;
}
/**
* @param writeMessageStore
* the writeMessageStore to set
*/
public
void
setWriteMessageStore
(
MessageStore
writeMessageStore
)
{
this
.
writeMessageStore
=
writeMessageStore
;
}
public
void
buildRunningStats
(
HashMap
<
String
,
String
>
stats
)
{
Iterator
<
Entry
<
Integer
,
Long
>>
it
=
this
.
offsetTable
.
entrySet
().
iterator
();
Iterator
<
Map
.
Entry
<
Integer
,
Long
>>
it
=
this
.
offsetTable
.
entrySet
().
iterator
();
while
(
it
.
hasNext
())
{
Entry
<
Integer
,
Long
>
next
=
it
.
next
();
Map
.
Entry
<
Integer
,
Long
>
next
=
it
.
next
();
int
queueId
=
delayLevel2QueueId
(
next
.
getKey
());
long
delayOffset
=
next
.
getValue
();
long
maxOffset
=
this
.
defaultMessageStore
.
getMaxOffsetInQueue
(
SCHEDULE_TOPIC
,
queueId
);
...
...
@@ -102,35 +111,45 @@ public class ScheduleMessageService extends ConfigManager {
}
public
void
start
()
{
if
(
started
.
compareAndSet
(
false
,
true
))
{
this
.
timer
=
new
Timer
(
"ScheduleMessageTimerThread"
,
true
);
for
(
Map
.
Entry
<
Integer
,
Long
>
entry
:
this
.
delayLevelTable
.
entrySet
())
{
Integer
level
=
entry
.
getKey
();
Long
timeDelay
=
entry
.
getValue
();
Long
offset
=
this
.
offsetTable
.
get
(
level
);
if
(
null
==
offset
)
{
offset
=
0L
;
}
for
(
Map
.
Entry
<
Integer
,
Long
>
entry
:
this
.
delayLevelTable
.
entrySet
())
{
Integer
level
=
entry
.
getKey
();
Long
timeDelay
=
entry
.
getValue
();
Long
offset
=
this
.
offsetTable
.
get
(
level
);
if
(
null
==
offset
)
{
offset
=
0L
;
}
if
(
timeDelay
!=
null
)
{
this
.
timer
.
schedule
(
new
DeliverDelayedMessageTimerTask
(
level
,
offset
),
FIRST_DELAY_TIME
);
if
(
timeDelay
!=
null
)
{
this
.
timer
.
schedule
(
new
DeliverDelayedMessageTimerTask
(
level
,
offset
),
FIRST_DELAY_TIME
);
}
}
}
this
.
timer
.
scheduleAtFixedRate
(
new
TimerTask
()
{
this
.
timer
.
scheduleAtFixedRate
(
new
TimerTask
()
{
@Override
public
void
run
()
{
try
{
ScheduleMessageService
.
this
.
persist
();
}
catch
(
Throwable
e
)
{
log
.
error
(
"scheduleAtFixedRate flush exception"
,
e
);
@Override
public
void
run
()
{
try
{
if
(
started
.
get
())
ScheduleMessageService
.
this
.
persist
();
}
catch
(
Throwable
e
)
{
log
.
error
(
"scheduleAtFixedRate flush exception"
,
e
);
}
}
}
}
,
10000
,
this
.
defaultMessageStore
.
getMessageStoreConfig
().
getFlushDelayOffsetInterval
());
}
,
10000
,
this
.
defaultMessageStore
.
getMessageStoreConfig
().
getFlushDelayOffsetInterval
());
}
}
public
void
shutdown
()
{
this
.
timer
.
cancel
();
if
(
this
.
started
.
compareAndSet
(
true
,
false
))
{
if
(
null
!=
this
.
timer
)
this
.
timer
.
cancel
();
}
}
public
boolean
isStarted
()
{
return
started
.
get
();
}
public
int
getMaxDelayLevel
()
{
...
...
@@ -214,7 +233,9 @@ public class ScheduleMessageService extends ConfigManager {
@Override
public
void
run
()
{
try
{
this
.
executeOnTimeup
();
if
(
isStarted
())
{
this
.
executeOnTimeup
();
}
}
catch
(
Exception
e
)
{
// XXX: warn and notify me
log
.
error
(
"ScheduleMessageService, executeOnTimeup exception"
,
e
);
...
...
@@ -285,7 +306,7 @@ public class ScheduleMessageService extends ConfigManager {
try
{
MessageExtBrokerInner
msgInner
=
this
.
messageTimeup
(
msgExt
);
PutMessageResult
putMessageResult
=
ScheduleMessageService
.
this
.
default
MessageStore
ScheduleMessageService
.
this
.
write
MessageStore
.
putMessage
(
msgInner
);
if
(
putMessageResult
!=
null
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录