当前位置: 首页 > news >正文

免费网页模板网站中华住房和城乡建设局网站

免费网页模板网站,中华住房和城乡建设局网站,wordpress购物,360官方下载官网下面是一个使用Java实现的RocketMQ示例代码,用于发送和消费消息: 首先,您需要下载并安装RocketMQ,并启动NameServer和Broker。 接下来,您可以使用以下示例代码来发送和消费消息: Producer.java文件&…

下面是一个使用Java实现的RocketMQ示例代码,用于发送和消费消息:

首先,您需要下载并安装RocketMQ,并启动NameServer和Broker。

接下来,您可以使用以下示例代码来发送和消费消息:

Producer.java文件:

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.common.message.Message;public class Producer {public static void main(String[] args) {try {// 创建一个DefaultMQProducer实例DefaultMQProducer producer = new DefaultMQProducer("producer_group");// 设置NameServer地址producer.setNamesrvAddr("localhost:9876");// 启动Producer实例producer.start();// 创建消息对象Message message = new Message("topic_name", "tag", "Hello, RocketMQ!".getBytes());// 发送消息producer.send(message);// 关闭Producer实例producer.shutdown();} catch (Exception e) {e.printStackTrace();}}
}

Consumer.java文件:

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.MessageListenerConcurrently;
import org.apache.rocketmq.common.consumer.ConsumeFromWhere;
import org.apache.rocketmq.common.message.MessageExt;public class Consumer {public static void main(String[] args) {try {// 创建一个DefaultMQPushConsumer实例DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("consumer_group");// 设置NameServer地址consumer.setNamesrvAddr("localhost:9876");// 设置消费开始位置consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);// 订阅主题和标签consumer.subscribe("topic_name", "tag");// 注册消息监听器consumer.registerMessageListener((MessageListenerConcurrently) (msgs, context) -> {for (MessageExt msg : msgs) {System.out.println("Received message: " + new String(msg.getBody()));}return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;});// 启动Consumer实例consumer.start();} catch (Exception e) {e.printStackTrace();}}
}

在上述示例代码中,Producer类用于发送消息,而Consumer类用于接收和处理消息。

在Producer类中,我们创建一个DefaultMQProducer实例,并设置NameServer的地址。然后,我们创建一个消息对象,指定主题、标签和消息内容。最后,通过调用send方法发送消息。

在Consumer类中,我们创建一个DefaultMQPushConsumer实例,并设置NameServer的地址。然后,我们设置消费开始位置和订阅特定的主题和标签。注册一个消息监听器,用于处理接收到的消息。最后,调用start方法启动Consumer实例。

请确保您已正确配置RocketMQ服务器和相关依赖项,并根据需要更改服务器地址、主题和标签。运行Producer和Consumer代码后,您将看到Producer发送的消息在Consumer端被接收和打印出来。



当然!这里是另一个使用Java实现的RocketMQ示例代码,用于发送事务消息:

首先,您需要下载并安装RocketMQ,并启动NameServer和Broker。

接下来,您可以使用以下示例代码来发送和处理事务消息:

TransactionProducer.java文件:

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.client.producer.LocalTransactionState;
import org.apache.rocketmq.client.producer.TransactionMQProducer;
import org.apache.rocketmq.client.producer.TransactionSendResult;
import org.apache.rocketmq.client.producer.TransactionListener;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.common.message.MessageExt;public class TransactionProducer {public static void main(String[] args) {try {// 创建一个TransactionMQProducer实例TransactionMQProducer producer = new TransactionMQProducer("producer_group");// 设置NameServer地址producer.setNamesrvAddr("localhost:9876");// 设置事务监听器producer.setTransactionListener(new TransactionListener() {@Overridepublic LocalTransactionState executeLocalTransaction(Message msg, Object arg) {// 执行本地事务,根据业务逻辑返回LocalTransactionState// 如果事务执行成功,返回COMMIT_MESSAGE// 如果事务执行失败,返回ROLLBACK_MESSAGE// 如果事务状态不确定,返回UNKNOWreturn LocalTransactionState.COMMIT_MESSAGE;}@Overridepublic LocalTransactionState checkLocalTransaction(MessageExt msg) {// 检查本地事务状态,根据消息内容返回LocalTransactionState// 如果事务已提交,返回COMMIT_MESSAGE// 如果事务已回滚,返回ROLLBACK_MESSAGE// 如果事务状态不确定,返回UNKNOWreturn LocalTransactionState.COMMIT_MESSAGE;}});// 启动Producer实例producer.start();// 创建消息对象Message message = new Message("topic_name", "tag", "Hello, RocketMQ!".getBytes());// 发送事务消息TransactionSendResult sendResult = producer.sendMessageInTransaction(message, null);System.out.println("Transaction Send Result: " + sendResult.getLocalTransactionState());// 关闭Producer实例producer.shutdown();} catch (Exception e) {e.printStackTrace();}}
}

在上述示例代码中,我们创建了一个TransactionMQProducer实例,并设置了NameServer的地址。然后,我们设置了事务监听器,其中包含executeLocalTransaction方法和checkLocalTransaction方法。在executeLocalTransaction方法中,您可以执行本地事务操作,并根据事务结果返回适当的LocalTransactionState。在checkLocalTransaction方法中,您可以检查本地事务状态,并返回相应的LocalTransactionState。

在主程序中,我们创建了一个消息对象,并通过调用sendMessageInTransaction方法发送事务消息。然后,我们打印事务发送结果的LocalTransactionState。

请确保您已正确配置RocketMQ服务器和相关依赖项,并根据需要更改服务器地址、主题和标签。运行TransactionProducer代码后,您将看到事务消息发送的结果。根据本地事务执行的结果和检查的结果,LocalTransactionState将被设置为相应的状态(

COMMIT_MESSAGE、ROLLBACK_MESSAGE或UNKNOW)。



当然!这里是另一个使用Java实现的RocketMQ示例代码,用于顺序消息的发送和消费:

首先,您需要下载并安装RocketMQ,并启动NameServer和Broker。

接下来,您可以使用以下示例代码来发送和消费顺序消息:

顺序消息生产者 (OrderedProducer.java):

import org.apache.rocketmq.client.producer.DefaultMQProducer;
import org.apache.rocketmq.client.producer.SendResult;
import org.apache.rocketmq.common.message.Message;
import org.apache.rocketmq.common.message.MessageQueueSelector;
import org.apache.rocketmq.common.protocol.heartbeat.MessageModel;import java.util.List;public class OrderedProducer {public static void main(String[] args) {try {// 创建一个DefaultMQProducer实例DefaultMQProducer producer = new DefaultMQProducer("producer_group");// 设置NameServer地址producer.setNamesrvAddr("localhost:9876");// 启动Producer实例producer.start();// 发送顺序消息for (int i = 0; i < 10; i++) {Message message = new Message("topic_name", "tag", ("Hello, RocketMQ! " + i).getBytes());SendResult sendResult = producer.send(message, new MessageQueueSelector() {@Overridepublic MessageQueue select(List<MessageQueue> mqs, Message msg, Object arg) {Integer orderId = (Integer) arg;int index = orderId % mqs.size();return mqs.get(index);}}, i);System.out.println("Send Result: " + sendResult);}// 关闭Producer实例producer.shutdown();} catch (Exception e) {e.printStackTrace();}}
}

顺序消息消费者 (OrderedConsumer.java):

import org.apache.rocketmq.client.consumer.DefaultMQPushConsumer;
import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyContext;
import org.apache.rocketmq.client.consumer.listener.ConsumeConcurrentlyStatus;
import org.apache.rocketmq.client.consumer.listener.MessageListenerConcurrently;
import org.apache.rocketmq.common.message.MessageExt;import java.util.List;public class OrderedConsumer {public static void main(String[] args) {try {// 创建一个DefaultMQPushConsumer实例DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("consumer_group");// 设置NameServer地址consumer.setNamesrvAddr("localhost:9876");// 设置消费模式为集群模式consumer.setMessageModel(MessageModel.CLUSTERING);// 订阅主题和标签consumer.subscribe("topic_name", "tag");// 注册消息监听器consumer.registerMessageListener((MessageListenerConcurrently) (msgs, context) -> {for (MessageExt msg : msgs) {System.out.println("Received message: " + new String(msg.getBody()) + ", QueueId: " + msg.getQueueId());}return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;});// 启动Consumer实例consumer.start();} catch (Exception e) {e.printStackTrace();}}
}

在上述示例代码中,OrderedProducer类用于发送顺序消息,而OrderedConsumer类用于接收和处理顺序消息。

在OrderedProducer类中,我们创建了一个DefaultMQProducer实例,并设置了Name

Server的地址。然后,我们使用循环发送了10条顺序消息。在发送消息时,我们使用MessageQueueSelector来选择要发送的消息队列,并通过参数指定了消息的顺序。每条消息都会返回一个SendResult对象。

在OrderedConsumer类中,我们创建了一个DefaultMQPushConsumer实例,并设置了NameServer的地址。我们还设置了消费模式为集群模式,通过subscribe方法订阅特定的主题和标签。注册了一个消息监听器,用于处理接收到的消息。收到的消息将被打印出来,并附带消息所在的队列ID。

请确保您已正确配置RocketMQ服务器和相关依赖项,并根据需要更改服务器地址、主题和标签。运行OrderedProducer和OrderedConsumer代码后,您将看到顺序消息发送和消费的结果。每条消息都将按照发送时指定的顺序被消费。

http://www.yayakq.cn/news/578491/

相关文章:

  • 网站开发浏览器的使用怎么下载爱南宁app呢
  • 高校网站建设与管理问题分析公众号江苏建设信息网站
  • 漯河建设网站重庆公司做网站
  • 网站建设的公司有发展吗太原市建设局网站
  • 页面设计制作网站文章响应式网站
  • 建一个论坛网站怎么建北京网站设计公司兴田德润怎么样
  • seo整站优化外包哪家好晋城建设局网站
  • nodejs 网站开发模块网站建设课程小结
  • 西安在线秦皇岛优化seo
  • 怎样优化网站 优帮云找人帮忙注册app推广
  • 郑州网站优化技巧质量好网站建设商家
  • 外贸营销型网站案例江苏市场监督管理局
  • 一个ip做网站网站开发技术的发展
  • 四位一体网站开发市场调研的内容
  • 简单免费自建网站石家庄网站建设外包公司排名
  • 网站关键词有什么用网络营销促销形式
  • 网站涉及敏感视频等该怎么做wordpress 赞 分享
  • 怎么做网站背景图片wordpress导入sql
  • 餐饮网站建设方案廊坊网站建设系统
  • 特克斯与凯科斯群岛域名官方网站做网站不搭建本地环境
  • 商务网站建设设计结构内容360网站兼容模式
  • 银行收取网站建设费的会计科目北京pc28网站
  • 包装设计灵感网站app开发方式有哪些
  • 精英学校老师给学生做的网站龙华附近网站建设
  • 网站推广的方式有哪些?深圳龙岗有什么好玩的地方
  • 网站开发环境容易做的html5的网站
  • 柳州公司网站制作公司摄影作品展示网站设计
  • 做视频网站需要多少带宽微信微网站怎么进入
  • 安徽省建设厅查询网站建设模板类网站
  • 禅城网站开发口碑好的镇江网站建设