Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
s920243400
Rocketmq
提交
5d3560dc
R
Rocketmq
项目概览
s920243400
/
Rocketmq
与 Fork 源项目一致
Fork自
Apache RocketMQ / Rocketmq
通知
1
Star
1
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看板
提交
5d3560dc
编写于
11月 16, 2018
作者:
D
duhengforever
提交者:
von gosling
12月 07, 2018
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixed Transactional message will be lost under extreme condition
上级
f27dc755
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
22 deletion
+15
-22
broker/src/main/java/org/apache/rocketmq/broker/transaction/queue/TransactionalMessageServiceImpl.java
...er/transaction/queue/TransactionalMessageServiceImpl.java
+15
-22
未找到文件。
broker/src/main/java/org/apache/rocketmq/broker/transaction/queue/TransactionalMessageServiceImpl.java
浏览文件 @
5d3560dc
...
@@ -198,7 +198,7 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
...
@@ -198,7 +198,7 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
if
(
null
!=
checkImmunityTimeStr
)
{
if
(
null
!=
checkImmunityTimeStr
)
{
checkImmunityTime
=
getImmunityTime
(
checkImmunityTimeStr
,
transactionTimeout
);
checkImmunityTime
=
getImmunityTime
(
checkImmunityTimeStr
,
transactionTimeout
);
if
(
valueOfCurrentMinusBorn
<
checkImmunityTime
)
{
if
(
valueOfCurrentMinusBorn
<
checkImmunityTime
)
{
if
(
checkPrepareQueueOffset
(
removeMap
,
doneOpOffset
,
msgExt
,
checkImmunityTime
))
{
if
(
checkPrepareQueueOffset
(
removeMap
,
doneOpOffset
,
msgExt
))
{
newOffset
=
i
+
1
;
newOffset
=
i
+
1
;
i
++;
i
++;
continue
;
continue
;
...
@@ -315,33 +315,26 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
...
@@ -315,33 +315,26 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
* @param removeMap Op message map to determine whether a half message was responded by producer.
* @param removeMap Op message map to determine whether a half message was responded by producer.
* @param doneOpOffset Op Message which has been checked.
* @param doneOpOffset Op Message which has been checked.
* @param msgExt Half message
* @param msgExt Half message
* @param checkImmunityTime User defined time to avoid being detected early.
* @return Return true if put success, otherwise return false.
* @return Return true if put success, otherwise return false.
*/
*/
private
boolean
checkPrepareQueueOffset
(
HashMap
<
Long
,
Long
>
removeMap
,
List
<
Long
>
doneOpOffset
,
MessageExt
msgExt
,
private
boolean
checkPrepareQueueOffset
(
HashMap
<
Long
,
Long
>
removeMap
,
List
<
Long
>
doneOpOffset
,
long
checkImmunityTime
)
{
MessageExt
msgExt
)
{
if
(
System
.
currentTimeMillis
()
-
msgExt
.
getBornTimestamp
()
<
checkImmunityTime
)
{
String
prepareQueueOffsetStr
=
msgExt
.
getUserProperty
(
MessageConst
.
PROPERTY_TRANSACTION_PREPARED_QUEUE_OFFSET
);
String
prepareQueueOffsetStr
=
msgExt
.
getUserProperty
(
MessageConst
.
PROPERTY_TRANSACTION_PREPARED_QUEUE_OFFSET
);
if
(
null
==
prepareQueueOffsetStr
)
{
if
(
null
==
prepareQueueOffsetStr
)
{
return
putImmunityMsgBackToHalfQueue
(
msgExt
);
return
putImmunityMsgBackToHalfQueue
(
msgExt
);
}
else
{
long
prepareQueueOffset
=
getLong
(
prepareQueueOffsetStr
);
if
(-
1
==
prepareQueueOffset
)
{
return
false
;
}
else
{
}
else
{
long
prepareQueueOffset
=
getLong
(
prepareQueueOffsetStr
);
if
(
removeMap
.
containsKey
(
prepareQueueOffset
))
{
if
(-
1
==
prepareQueueOffset
)
{
long
tmpOpOffset
=
removeMap
.
remove
(
prepareQueueOffset
);
return
false
;
doneOpOffset
.
add
(
tmpOpOffset
);
return
true
;
}
else
{
}
else
{
if
(
removeMap
.
containsKey
(
prepareQueueOffset
))
{
return
putImmunityMsgBackToHalfQueue
(
msgExt
);
long
tmpOpOffset
=
removeMap
.
remove
(
prepareQueueOffset
);
doneOpOffset
.
add
(
tmpOpOffset
);
return
true
;
}
else
{
return
putImmunityMsgBackToHalfQueue
(
msgExt
);
}
}
}
}
}
}
else
{
return
true
;
}
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录