依赖
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-common</artifactId>
<version>4.9.1</version>
</dependency>
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-client</artifactId>
<version>4.9.1</version>
</dependency>
发送消息
public void sendMessageUseTransaction() throws Exception {
TransactionMQProducer producer = new TransactionMQProducer("mygroup");
producer.setNamesrvAddr("127.0.0.1:9876");
producer.setTransactionListener(new TransactionListener() {
long time = 0;
@Override
public LocalTransactionState executeLocalTransaction(Message message, Object o) {
time = System.currentTimeMillis();
System.out.println("开始事务");
try {
Thread.sleep(100000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("结束事务");
return LocalTransactionState.COMMIT_MESSAGE;
}
@Override
public LocalTransactionState checkLocalTransaction(MessageExt messageExt) {
long temp = System.currentTimeMillis() - time;
temp /= 1000;
System.out.println("事务执行" + temp + "s后检查事务:" + messageExt.getTransactionId());
return LocalTransactionState.UNKNOW;
}
});
producer.start();
String body = UUID.randomUUID().toString();
Message message = new Message("mytopic", body.getBytes());
TransactionSendResult sendResult = producer.sendMessageInTransaction(message, null);
System.out.println("发送完成");
}
接收消息
public void receiveMessage() throws Exception {
DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("mygroupp");
consumer.setNamesrvAddr("127.0.0.1:9876");
consumer.subscribe("mytopic", "*");
consumer.setConsumeThreadMax(2);
consumer.setConsumeThreadMin(2);
consumer.registerMessageListener(new MessageListenerConcurrently() {
@Override
public ConsumeConcurrentlyStatus consumeMessage(
List<MessageExt> list, ConsumeConcurrentlyContext consumeConcurrentlyContext) {
for (MessageExt messageExt : list) {
byte[] body = messageExt.getBody();
String s = new String(body);
String name = Thread.currentThread().getName();
System.out.println(s + "\t" + name);
}
return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
}
});
consumer.setMessageModel(MessageModel.CLUSTERING);
consumer.start();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!