Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Apache RocketMQ
Rocketmq
提交
1f106d77
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看板
提交
1f106d77
编写于
1月 07, 2020
作者:
D
duhenglucky
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(pull_consumer) refactor the consumer offset update logic
上级
50ba523b
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
15 addition
and
29 deletion
+15
-29
client/src/main/java/org/apache/rocketmq/client/consumer/DefaultLitePullConsumer.java
...che/rocketmq/client/consumer/DefaultLitePullConsumer.java
+1
-1
client/src/main/java/org/apache/rocketmq/client/impl/consumer/AssignedMessageQueue.java
...e/rocketmq/client/impl/consumer/AssignedMessageQueue.java
+4
-0
client/src/main/java/org/apache/rocketmq/client/impl/consumer/DefaultLitePullConsumerImpl.java
...tmq/client/impl/consumer/DefaultLitePullConsumerImpl.java
+10
-28
未找到文件。
client/src/main/java/org/apache/rocketmq/client/consumer/DefaultLitePullConsumer.java
浏览文件 @
1f106d77
...
@@ -269,7 +269,7 @@ public class DefaultLitePullConsumer extends ClientConfig implements LitePullCon
...
@@ -269,7 +269,7 @@ public class DefaultLitePullConsumer extends ClientConfig implements LitePullCon
@Override
@Override
public
void
commitSync
()
{
public
void
commitSync
()
{
this
.
defaultLitePullConsumerImpl
.
commit
Sync
();
this
.
defaultLitePullConsumerImpl
.
commit
All
();
}
}
@Override
@Override
...
...
client/src/main/java/org/apache/rocketmq/client/impl/consumer/AssignedMessageQueue.java
浏览文件 @
1f106d77
...
@@ -177,6 +177,10 @@ public class AssignedMessageQueue {
...
@@ -177,6 +177,10 @@ public class AssignedMessageQueue {
}
}
}
}
public
Set
<
MessageQueue
>
getAssignedMessageQueues
()
{
return
this
.
assignedMessageQueueState
.
keySet
();
}
private
class
MessageQueueState
{
private
class
MessageQueueState
{
private
MessageQueue
messageQueue
;
private
MessageQueue
messageQueue
;
private
ProcessQueue
processQueue
;
private
ProcessQueue
processQueue
;
...
...
client/src/main/java/org/apache/rocketmq/client/impl/consumer/DefaultLitePullConsumerImpl.java
浏览文件 @
1f106d77
...
@@ -590,37 +590,14 @@ public class DefaultLitePullConsumerImpl implements MQConsumerInner {
...
@@ -590,37 +590,14 @@ public class DefaultLitePullConsumerImpl implements MQConsumerInner {
}
}
}
}
public
synchronized
void
commit
Sync
()
{
public
synchronized
void
commit
All
()
{
try
{
try
{
for
(
MessageQueue
messageQueue
:
assignedMessageQueue
.
messageQueues
())
{
for
(
MessageQueue
messageQueue
:
assignedMessageQueue
.
messageQueues
())
{
long
consumerOffset
=
assignedMessageQueue
.
getConsumerOffset
(
messageQueue
);
long
consumerOffset
=
assignedMessageQueue
.
getConsumerOffset
(
messageQueue
);
if
(
consumerOffset
!=
-
1
)
{
if
(
consumerOffset
!=
-
1
)
{
ProcessQueue
processQueue
=
assignedMessageQueue
.
getProcessQueue
(
messageQueue
);
ProcessQueue
processQueue
=
assignedMessageQueue
.
getProcessQueue
(
messageQueue
);
long
preConsumerOffset
=
this
.
getOffsetStore
().
readOffset
(
messageQueue
,
ReadOffsetType
.
READ_FROM_MEMORY
);
if
(
processQueue
!=
null
&&
!
processQueue
.
isDropped
())
{
if
(
processQueue
!=
null
&&
!
processQueue
.
isDropped
()
&&
consumerOffset
!=
preConsumerOffset
)
{
updateConsumeOffset
(
messageQueue
,
consumerOffset
);
updateConsumeOffset
(
messageQueue
,
consumerOffset
);
updateConsumeOffsetToBroker
(
messageQueue
,
consumerOffset
,
false
);
}
}
}
if
(
defaultLitePullConsumer
.
getMessageModel
()
==
MessageModel
.
BROADCASTING
)
{
offsetStore
.
persistAll
(
assignedMessageQueue
.
messageQueues
());
}
}
catch
(
Exception
e
)
{
log
.
error
(
"An error occurred when update consume offset synchronously."
,
e
);
}
}
private
synchronized
void
commitAll
()
{
try
{
for
(
MessageQueue
messageQueue
:
assignedMessageQueue
.
messageQueues
())
{
long
consumerOffset
=
assignedMessageQueue
.
getConsumerOffset
(
messageQueue
);
if
(
consumerOffset
!=
-
1
)
{
ProcessQueue
processQueue
=
assignedMessageQueue
.
getProcessQueue
(
messageQueue
);
long
preConsumerOffset
=
this
.
getOffsetStore
().
readOffset
(
messageQueue
,
ReadOffsetType
.
READ_FROM_MEMORY
);
if
(
processQueue
!=
null
&&
!
processQueue
.
isDropped
()
&&
consumerOffset
!=
preConsumerOffset
)
{
updateConsumeOffset
(
messageQueue
,
consumerOffset
);
updateConsumeOffsetToBroker
(
messageQueue
,
consumerOffset
,
true
);
}
}
}
}
}
}
...
@@ -927,11 +904,16 @@ public class DefaultLitePullConsumerImpl implements MQConsumerInner {
...
@@ -927,11 +904,16 @@ public class DefaultLitePullConsumerImpl implements MQConsumerInner {
try
{
try
{
checkServiceState
();
checkServiceState
();
Set
<
MessageQueue
>
mqs
=
new
HashSet
<
MessageQueue
>();
Set
<
MessageQueue
>
mqs
=
new
HashSet
<
MessageQueue
>();
if
(
this
.
subscriptionType
==
SubscriptionType
.
SUBSCRIBE
)
{
Set
<
MessageQueue
>
allocateMq
=
this
.
rebalanceImpl
.
getProcessQueueTable
().
keySet
();
Set
<
MessageQueue
>
allocateMq
=
this
.
rebalanceImpl
.
getProcessQueueTable
().
keySet
();
mqs
.
addAll
(
allocateMq
);
mqs
.
addAll
(
allocateMq
);
}
else
if
(
this
.
subscriptionType
==
SubscriptionType
.
ASSIGN
)
{
Set
<
MessageQueue
>
assignedMessageQueue
=
this
.
assignedMessageQueue
.
getAssignedMessageQueues
();
mqs
.
addAll
(
assignedMessageQueue
);
}
this
.
offsetStore
.
persistAll
(
mqs
);
this
.
offsetStore
.
persistAll
(
mqs
);
}
catch
(
Exception
e
)
{
}
catch
(
Exception
e
)
{
log
.
error
(
"
group: "
+
this
.
defaultLitePullConsumer
.
getConsumerGroup
()
+
" persistConsumerOffset exception"
,
e
);
log
.
error
(
"
Persist consumer offset error for group: {} "
,
this
.
defaultLitePullConsumer
.
getConsumerGroup
()
,
e
);
}
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录