Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
R
rocket-mq-demo
Project
Project
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
Graph
比较
统计图
议题
0
议题
0
列表
看板
标记
Milestones
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
songchuancai
rocket-mq-demo
Commits
80392366
提交
80392366
authored
11月 18, 2021
作者:
scc
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
test5
上级
43f1dc48
显示空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
68 行增加
和
1 行删除
+68
-1
StringConsumer.java
...ava/com/example/rocketmqdemo/consumer/StringConsumer.java
+0
-1
MqMessageController.java
.../example/rocketmqdemo/controller/MqMessageController.java
+26
-0
MyRocketMQLocalTransactionListener.java
...etmqdemo/listener/MyRocketMQLocalTransactionListener.java
+42
-0
没有找到文件。
src/main/java/com/example/rocketmqdemo/consumer/StringConsumer.java
浏览文件 @
80392366
...
...
@@ -9,7 +9,6 @@ import org.springframework.stereotype.Service;
@RocketMQMessageListener
(
consumerGroup
=
"${xc.rocketmq2.string-consumer-group}"
,
topic
=
"${xc.rocketmq2.topic-string}"
)
public
class
StringConsumer
implements
RocketMQListener
<
String
>
{
@Override
public
void
onMessage
(
String
message
)
{
System
.
out
.
println
(
"消费字符串消息:"
+
message
);
...
...
src/main/java/com/example/rocketmqdemo/controller/MqMessageController.java
浏览文件 @
80392366
...
...
@@ -9,13 +9,19 @@ import org.apache.rocketmq.common.CountDownLatch2;
import
org.apache.rocketmq.remoting.exception.RemotingException
;
import
org.apache.rocketmq.spring.core.RocketMQTemplate
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.messaging.Message
;
import
org.springframework.messaging.MessageHeaders
;
import
org.springframework.messaging.support.GenericMessage
;
import
org.springframework.messaging.support.MessageBuilder
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestParam
;
import
org.springframework.web.bind.annotation.RestController
;
import
java.io.UnsupportedEncodingException
;
import
java.util.ArrayList
;
import
java.util.HashMap
;
import
java.util.List
;
import
java.util.Map
;
import
java.util.concurrent.TimeUnit
;
@RestController
...
...
@@ -85,4 +91,23 @@ public class MqMessageController {
return
"单向发送消息成功"
;
}
@RequestMapping
(
"/sendDelayMessage"
)
public
String
sendDelayMessage
(
@RequestParam
(
"delay"
)
Integer
delay
)
throws
Exception
{
rocketMQTemplate
.
syncSend
(
xcRocketMq2
.
getTopicString
(),
MessageBuilder
.
withPayload
(
"收到延迟"
+
delay
+
"秒消息"
).
build
(),
3000
,
delay
);
return
"延迟消息发送成功"
;
}
@RequestMapping
(
"/sendTransactionMessage"
)
public
String
sendTransactionMessage
(
@RequestParam
(
"type"
)
String
type
)
throws
Exception
{
Map
<
String
,
String
>
header
=
new
HashMap
<>();
header
.
put
(
"type"
,
type
);
Message
message
=
new
GenericMessage
(
"事务消息"
,
header
);
rocketMQTemplate
.
sendMessageInTransaction
(
xcRocketMq2
.
getTopicString
(),
message
,
null
);
return
"事务消息发送成功"
;
}
}
\ No newline at end of file
src/main/java/com/example/rocketmqdemo/listener/MyRocketMQLocalTransactionListener.java
0 → 100644
浏览文件 @
80392366
package
com
.
example
.
rocketmqdemo
.
listener
;
import
org.apache.rocketmq.spring.annotation.RocketMQTransactionListener
;
import
org.apache.rocketmq.spring.core.RocketMQLocalTransactionListener
;
import
org.apache.rocketmq.spring.core.RocketMQLocalTransactionState
;
import
org.springframework.messaging.Message
;
import
org.springframework.messaging.MessageHeaders
;
@RocketMQTransactionListener
public
class
MyRocketMQLocalTransactionListener
implements
RocketMQLocalTransactionListener
{
@Override
public
RocketMQLocalTransactionState
executeLocalTransaction
(
Message
message
,
Object
o
)
{
//执行本地事务
System
.
out
.
println
(
"本地事务执行。。。。"
);
try
{
Thread
.
sleep
(
5000
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
System
.
out
.
println
(
"本地事务执行完成。。。。"
);
MessageHeaders
headers
=
message
.
getHeaders
();
String
type
=
headers
.
get
(
"type"
).
toString
();
if
(
type
.
equalsIgnoreCase
(
"commit"
)){
return
RocketMQLocalTransactionState
.
COMMIT
;
//根据本地事务的提交完成情况返回不同的标志
}
else
if
(
type
.
equalsIgnoreCase
(
"unknown"
))
return
RocketMQLocalTransactionState
.
UNKNOWN
;
else
{
return
RocketMQLocalTransactionState
.
ROLLBACK
;
}
}
@Override
public
RocketMQLocalTransactionState
checkLocalTransaction
(
Message
message
)
{
System
.
out
.
println
(
"回查操作"
);
try
{
Thread
.
sleep
(
10000
);
}
catch
(
InterruptedException
e
)
{
e
.
printStackTrace
();
}
return
RocketMQLocalTransactionState
.
COMMIT
;
//根据本地事务的提交完成情况返回不同的标志
}
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论