Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Kwan的解忧杂货铺@新空间代码工作室
Rocketmq
提交
6a6f2e7d
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看板
未验证
提交
6a6f2e7d
编写于
10月 31, 2019
作者:
H
Heng Du
提交者:
GitHub
10月 31, 2019
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1544 from areyouok/4.5.2.fix
[ISSUE #1519]Optimise performance/stability of transaction message
上级
fde3f322
6fb66c1f
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
66 addition
and
25 deletion
+66
-25
broker/src/main/java/org/apache/rocketmq/broker/processor/EndTransactionProcessor.java
...he/rocketmq/broker/processor/EndTransactionProcessor.java
+1
-1
broker/src/main/java/org/apache/rocketmq/broker/transaction/AbstractTransactionalMessageCheckListener.java
...ransaction/AbstractTransactionalMessageCheckListener.java
+2
-1
broker/src/main/java/org/apache/rocketmq/broker/transaction/queue/TransactionalMessageBridge.java
.../broker/transaction/queue/TransactionalMessageBridge.java
+1
-1
broker/src/main/java/org/apache/rocketmq/broker/transaction/queue/TransactionalMessageServiceImpl.java
...er/transaction/queue/TransactionalMessageServiceImpl.java
+5
-4
example/src/main/java/org/apache/rocketmq/example/benchmark/Consumer.java
.../java/org/apache/rocketmq/example/benchmark/Consumer.java
+4
-0
example/src/main/java/org/apache/rocketmq/example/benchmark/TransactionProducer.java
...pache/rocketmq/example/benchmark/TransactionProducer.java
+53
-18
未找到文件。
broker/src/main/java/org/apache/rocketmq/broker/processor/EndTransactionProcessor.java
浏览文件 @
6a6f2e7d
...
...
@@ -55,7 +55,7 @@ public class EndTransactionProcessor implements NettyRequestProcessor {
final
RemotingCommand
response
=
RemotingCommand
.
createResponseCommand
(
null
);
final
EndTransactionRequestHeader
requestHeader
=
(
EndTransactionRequestHeader
)
request
.
decodeCommandCustomHeader
(
EndTransactionRequestHeader
.
class
);
LOGGER
.
info
(
"Transaction request:{}"
,
requestHeader
);
LOGGER
.
debug
(
"Transaction request:{}"
,
requestHeader
);
if
(
BrokerRole
.
SLAVE
==
brokerController
.
getMessageStoreConfig
().
getBrokerRole
())
{
response
.
setCode
(
ResponseCode
.
SLAVE_NOT_AVAILABLE
);
LOGGER
.
warn
(
"Message store is slave mode, so end transaction is forbidden. "
);
...
...
broker/src/main/java/org/apache/rocketmq/broker/transaction/AbstractTransactionalMessageCheckListener.java
浏览文件 @
6a6f2e7d
...
...
@@ -30,6 +30,7 @@ import java.util.concurrent.ArrayBlockingQueue;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.ThreadFactory
;
import
java.util.concurrent.ThreadPoolExecutor
;
import
java.util.concurrent.ThreadPoolExecutor.CallerRunsPolicy
;
import
java.util.concurrent.TimeUnit
;
public
abstract
class
AbstractTransactionalMessageCheckListener
{
...
...
@@ -48,7 +49,7 @@ public abstract class AbstractTransactionalMessageCheckListener {
thread
.
setName
(
"Transaction-msg-check-thread"
);
return
thread
;
}
});
}
,
new
CallerRunsPolicy
()
);
public
AbstractTransactionalMessageCheckListener
()
{
}
...
...
broker/src/main/java/org/apache/rocketmq/broker/transaction/queue/TransactionalMessageBridge.java
浏览文件 @
6a6f2e7d
...
...
@@ -141,6 +141,7 @@ public class TransactionalMessageBridge {
getMessageResult
.
getStatus
(),
topic
,
group
,
offset
);
break
;
case
NO_MESSAGE_IN_QUEUE:
case
OFFSET_OVERFLOW_ONE:
pullStatus
=
PullStatus
.
NO_NEW_MSG
;
LOGGER
.
warn
(
"No new message. GetMessageStatus={}, topic={}, groupId={}, requestOffset={}"
,
getMessageResult
.
getStatus
(),
topic
,
group
,
offset
);
...
...
@@ -149,7 +150,6 @@ public class TransactionalMessageBridge {
case
NO_MATCHED_LOGIC_QUEUE:
case
OFFSET_FOUND_NULL:
case
OFFSET_OVERFLOW_BADLY:
case
OFFSET_OVERFLOW_ONE:
case
OFFSET_TOO_SMALL:
pullStatus
=
PullStatus
.
OFFSET_ILLEGAL
;
LOGGER
.
warn
(
"Offset illegal. GetMessageStatus={}, topic={}, groupId={}, requestOffset={}"
,
...
...
broker/src/main/java/org/apache/rocketmq/broker/transaction/queue/TransactionalMessageServiceImpl.java
浏览文件 @
6a6f2e7d
...
...
@@ -159,7 +159,8 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
}
if
(
removeMap
.
containsKey
(
i
))
{
log
.
info
(
"Half offset {} has been committed/rolled back"
,
i
);
removeMap
.
remove
(
i
);
Long
removedOpOffset
=
removeMap
.
remove
(
i
);
doneOpOffset
.
add
(
removedOpOffset
);
}
else
{
GetResult
getResult
=
getHalfMsg
(
messageQueue
,
i
);
MessageExt
msgExt
=
getResult
.
getMsg
();
...
...
@@ -223,7 +224,7 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
listener
.
resolveHalfMsg
(
msgExt
);
}
else
{
pullResult
=
fillOpRemoveMap
(
removeMap
,
opQueue
,
pullResult
.
getNextBeginOffset
(),
halfOffset
,
doneOpOffset
);
log
.
info
(
"The miss offset:{} in messageQueue:{} need to get more opMsg, result is:{}"
,
i
,
log
.
debug
(
"The miss offset:{} in messageQueue:{} need to get more opMsg, result is:{}"
,
i
,
messageQueue
,
pullResult
);
continue
;
}
...
...
@@ -292,7 +293,7 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
}
for
(
MessageExt
opMessageExt
:
opMsg
)
{
Long
queueOffset
=
getLong
(
new
String
(
opMessageExt
.
getBody
(),
TransactionalMessageUtil
.
charset
));
log
.
info
(
"Topic: {} tags: {}, OpOffset: {}, HalfOffset: {}"
,
opMessageExt
.
getTopic
(),
log
.
debug
(
"Topic: {} tags: {}, OpOffset: {}, HalfOffset: {}"
,
opMessageExt
.
getTopic
(),
opMessageExt
.
getTags
(),
opMessageExt
.
getQueueOffset
(),
queueOffset
);
if
(
TransactionalMessageUtil
.
REMOVETAG
.
equals
(
opMessageExt
.
getTags
()))
{
if
(
queueOffset
<
miniOffset
)
{
...
...
@@ -460,7 +461,7 @@ public class TransactionalMessageServiceImpl implements TransactionalMessageServ
@Override
public
boolean
deletePrepareMessage
(
MessageExt
msgExt
)
{
if
(
this
.
transactionalMessageBridge
.
putOpMessage
(
msgExt
,
TransactionalMessageUtil
.
REMOVETAG
))
{
log
.
info
(
"Transaction op message write successfully. messageId={}, queueId={} msgExt:{}"
,
msgExt
.
getMsgId
(),
msgExt
.
getQueueId
(),
msgExt
);
log
.
debug
(
"Transaction op message write successfully. messageId={}, queueId={} msgExt:{}"
,
msgExt
.
getMsgId
(),
msgExt
.
getQueueId
(),
msgExt
);
return
true
;
}
else
{
log
.
error
(
"Transaction op message write failed. messageId is {}, queueId is {}"
,
msgExt
.
getMsgId
(),
msgExt
.
getQueueId
());
...
...
example/src/main/java/org/apache/rocketmq/example/benchmark/Consumer.java
浏览文件 @
6a6f2e7d
...
...
@@ -103,6 +103,10 @@ public class Consumer {
},
10000
,
10000
);
DefaultMQPushConsumer
consumer
=
new
DefaultMQPushConsumer
(
group
);
if
(
commandLine
.
hasOption
(
'n'
))
{
String
ns
=
commandLine
.
getOptionValue
(
'n'
);
consumer
.
setNamesrvAddr
(
ns
);
}
consumer
.
setInstanceName
(
Long
.
toString
(
System
.
currentTimeMillis
()));
if
(
filterType
==
null
||
expression
==
null
)
{
...
...
example/src/main/java/org/apache/rocketmq/example/benchmark/TransactionProducer.java
浏览文件 @
6a6f2e7d
...
...
@@ -24,6 +24,11 @@ import java.util.TimerTask;
import
java.util.concurrent.ExecutorService
;
import
java.util.concurrent.Executors
;
import
java.util.concurrent.atomic.AtomicLong
;
import
org.apache.commons.cli.CommandLine
;
import
org.apache.commons.cli.Option
;
import
org.apache.commons.cli.Options
;
import
org.apache.commons.cli.PosixParser
;
import
org.apache.rocketmq.client.exception.MQClientException
;
import
org.apache.rocketmq.client.producer.LocalTransactionExecuter
;
import
org.apache.rocketmq.client.producer.LocalTransactionState
;
...
...
@@ -33,20 +38,19 @@ import org.apache.rocketmq.client.producer.TransactionMQProducer;
import
org.apache.rocketmq.common.message.Message
;
import
org.apache.rocketmq.common.message.MessageExt
;
import
org.apache.rocketmq.remoting.common.RemotingHelper
;
import
org.apache.rocketmq.srvutil.ServerUtil
;
public
class
TransactionProducer
{
private
static
int
threadCount
;
private
static
int
messageSize
;
private
static
boolean
ischeck
;
private
static
boolean
ischeckffalse
;
public
static
void
main
(
String
[]
args
)
throws
MQClientException
,
UnsupportedEncodingException
{
threadCount
=
args
.
length
>=
1
?
Integer
.
parseInt
(
args
[
0
])
:
32
;
messageSize
=
args
.
length
>=
2
?
Integer
.
parseInt
(
args
[
1
])
:
1024
*
2
;
ischeck
=
args
.
length
>=
3
&&
Boolean
.
parseBoolean
(
args
[
2
]);
ischeckffalse
=
args
.
length
>=
4
&&
Boolean
.
parseBoolean
(
args
[
3
]);
Options
options
=
ServerUtil
.
buildCommandlineOptions
(
new
Options
());
CommandLine
commandLine
=
ServerUtil
.
parseCmdLine
(
"TransactionProducer"
,
args
,
buildCommandlineOptions
(
options
),
new
PosixParser
());
final
Message
msg
=
buildMessage
(
messageSize
);
final
String
topic
=
commandLine
.
hasOption
(
't'
)
?
commandLine
.
getOptionValue
(
't'
).
trim
()
:
"BenchmarkTest"
;
final
int
threadCount
=
commandLine
.
hasOption
(
'w'
)
?
Integer
.
parseInt
(
commandLine
.
getOptionValue
(
'w'
))
:
32
;
final
int
messageSize
=
commandLine
.
hasOption
(
's'
)
?
Integer
.
parseInt
(
commandLine
.
getOptionValue
(
's'
))
:
2048
;
final
boolean
ischeck
=
commandLine
.
hasOption
(
'c'
)
?
Boolean
.
parseBoolean
(
commandLine
.
getOptionValue
(
'c'
))
:
false
;
final
boolean
ischeckffalse
=
commandLine
.
hasOption
(
'r'
)
?
Boolean
.
parseBoolean
(
commandLine
.
getOptionValue
(
'r'
))
:
true
;
final
ExecutorService
sendThreadPool
=
Executors
.
newFixedThreadPool
(
threadCount
);
...
...
@@ -98,6 +102,10 @@ public class TransactionProducer {
producer
.
setInstanceName
(
Long
.
toString
(
System
.
currentTimeMillis
()));
producer
.
setTransactionCheckListener
(
transactionCheckListener
);
producer
.
setDefaultTopicQueueNums
(
1000
);
if
(
commandLine
.
hasOption
(
'n'
))
{
String
ns
=
commandLine
.
getOptionValue
(
'n'
);
producer
.
setNamesrvAddr
(
ns
);
}
producer
.
start
();
final
TransactionExecuterBImpl
tranExecuter
=
new
TransactionExecuterBImpl
(
ischeck
);
...
...
@@ -111,7 +119,7 @@ public class TransactionProducer {
// Thread.sleep(1000);
final
long
beginTimestamp
=
System
.
currentTimeMillis
();
SendResult
sendResult
=
producer
.
sendMessageInTransaction
(
msg
,
tranExecuter
,
null
);
producer
.
sendMessageInTransaction
(
buildMessage
(
messageSize
,
topic
)
,
tranExecuter
,
null
);
if
(
sendResult
!=
null
)
{
statsBenchmark
.
getSendRequestSuccessCount
().
incrementAndGet
();
statsBenchmark
.
getReceiveResponseSuccessCount
().
incrementAndGet
();
...
...
@@ -138,18 +146,45 @@ public class TransactionProducer {
}
}
private
static
Message
buildMessage
(
final
int
messageSize
)
throws
UnsupportedEncodingException
{
Message
msg
=
new
Message
();
msg
.
setTopic
(
"BenchmarkTest"
);
private
static
Message
buildMessage
(
final
int
messageSize
,
String
topic
)
{
try
{
Message
msg
=
new
Message
();
msg
.
setTopic
(
topic
);
StringBuilder
sb
=
new
StringBuilder
();
for
(
int
i
=
0
;
i
<
messageSize
;
i
+=
10
)
{
sb
.
append
(
"hello baby"
);
StringBuilder
sb
=
new
StringBuilder
();
for
(
int
i
=
0
;
i
<
messageSize
;
i
+=
10
)
{
sb
.
append
(
"hello baby"
);
}
msg
.
setBody
(
sb
.
toString
().
getBytes
(
RemotingHelper
.
DEFAULT_CHARSET
));
return
msg
;
}
catch
(
UnsupportedEncodingException
e
)
{
throw
new
RuntimeException
(
e
);
}
}
public
static
Options
buildCommandlineOptions
(
final
Options
options
)
{
Option
opt
=
new
Option
(
"w"
,
"threadCount"
,
true
,
"Thread count, Default: 32"
);
opt
.
setRequired
(
false
);
options
.
addOption
(
opt
);
opt
=
new
Option
(
"s"
,
"messageSize"
,
true
,
"Message Size, Default: 2048"
);
opt
.
setRequired
(
false
);
options
.
addOption
(
opt
);
opt
=
new
Option
(
"t"
,
"topic"
,
true
,
"Topic name, Default: BenchmarkTest"
);
opt
.
setRequired
(
false
);
options
.
addOption
(
opt
);
opt
=
new
Option
(
"c"
,
"check"
,
true
,
"Check the message, Default: false"
);
opt
.
setRequired
(
false
);
options
.
addOption
(
opt
);
opt
=
new
Option
(
"r"
,
"checkResult"
,
true
,
"Message check result, Default: true"
);
opt
.
setRequired
(
false
);
options
.
addOption
(
opt
);
msg
.
setBody
(
sb
.
toString
().
getBytes
(
RemotingHelper
.
DEFAULT_CHARSET
));
return
msg
;
return
options
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录