RocketMQ发送和接收方式详解

本文介绍了RocketMQ提供的四种消息发送方式(同步、异步、单向、顺序)以及接收方式(集群消费、广播消费、顺序消费、延迟消费和死信队列),并给出了相应的代码示例,帮助开发者根据业务需求选择合适的方法。
摘要由CSDN通过智能技术生成

RocketMQ有几种发送方式

RocketMQ 提供了几种不同的消息发送方式,以满足不同场景下的需求。这些发送方式主要包括:

同步发送(Synchronous):这是最常见的一种发送方式,客户端发送消息后,会等待服务器端的响应。只有当消息完全被服务器接收,客户端才会继续执行。这种方式适用于对可靠性要求较高的场景。

异步发送(Asynchronous):客户端在发送消息后不会立即等待服务器的响应,而是通过一个回调接口来处理服务器的响应,这样可以提高消息发送的吞吐量。这种方式适用于对响应时间要求较敏感的场景。

单向发送(One-way):这种方式是最轻量级的一种发送方式,客户端只负责发送消息,不等待服务器的响应,也不关心消息是否被服务器接收。这种方式的可靠性最低,但吞吐量最高,适用于对可靠性要求不高的日志收集等场景。

顺序发送(Ordered):RocketMQ 还支持顺序发送消息,确保特定主题的消息能按照发送的顺序被消费。这对于需要保证消息顺序的业务场景(如订单处理)非常重要。**顺序必须是同步的**

这些发送方式可以根据具体的业务需求和场景来选择使用,以达到最佳的性能和可靠性平衡。

不同发送方式的调用方式或者不同配置

在使用 RocketMQ 进行消息发送时,可以根据不同的发送需求选择合适的发送方式。以下是不同发送方式的基本调用方式或配置示例:

1. 同步发送(Synchronous)
同步发送是指消息发送方将消息发送给服务器后,会等待服务器的响应,确认消息已经被接收后才继续执行后续操作。

// 实例化消息生产者Producer
DefaultMQProducer producer = new DefaultMQProducer("ProducerGroupName");
// 设置NameServer地址
producer.setNamesrvAddr("nameserver1:9876");
// 启动Producer实例
producer.start();

// 创建消息实例,指定topic,tag和消息体
Message msg = new Message("TopicTest", "TagA", ("Hello RocketMQ").getBytes(RemotingHelper.DEFAULT_CHARSET));

// 调用send方法发送消息,并获取发送结果
SendResult sendResult = producer.send(msg);

// 打印发送结果
System.out.printf("%s%n", sendResult);

// 当不再发送消息时,关闭Producer实例
producer.shutdown();

2. 异步发送(Asynchronous)
异步发送是指消息发送方发送消息后,不会立即等待服务器的响应,而是提供一个回调接口,服务器响应时通过回调接口来通知发送方。

// 实例化消息生产者Producer
DefaultMQProducer producer = new DefaultMQProducer("ProducerGroupName");
// 设置NameServer地址
producer.setNamesrvAddr("nameserver1:9876");
// 启动Producer实例
producer.start();

// 创建消息实例,指定topic,tag和消息体
Message msg = new Message("TopicTest", "TagA", ("Hello RocketMQ").getBytes(RemotingHelper.DEFAULT_CHARSET));

// 异步发送消息
producer.send(msg, new SendCallback() {
   
    @Override
    public void onSuccess(SendResult sendResult) {
   
        // 消息发送成功的回调
        System.out.printf("%-10d OK %s %n", index, sendResult.getMsgId());
    }

    @Override
    public void onException(Throwable e) {
   
        // 消息发送失败的回调
        System.out.printf("%-10d Exception %s %n", index, e);
        
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值