RocketMq 顺序消费、分区消息、延迟发送消息、Topic、tag分类 实战 (延迟发送消息) (四)

延迟发送消息生产者配置

如下所示:@Bean注解向Spring容器注入一个名字叫delayOrderProducerBean、类型为OrderProducerBean 的对象(下文需要用到)

bash 复制代码
@Configuration
public class DelayProducerClient {

    @Autowired
    private RocketMqDelayProperties rocketMqDelayProperties;

    @Lazy
    @Bean(name = "delayOrderProducerBean",initMethod = "start", destroyMethod = "shutdown")
    public OrderProducerBean buildDelayOrderProducer() {
        OrderProducerBean orderProducerBean = new OrderProducerBean();
        orderProducerBean.setProperties(rocketMqDelayProperties.getProducerProperties());
        return orderProducerBean;
    }
}
bash 复制代码
  	@Autowired
    private RocketMqDelayProperties rocketMqDelayProperties;
	
	@Qualifier("delayOrderProducerBean")
    @Autowired
    private OrderProducerBean delayOrderProducerBean;
	
    public void sendDelayMQMessage(DelayBaseBo delayBaseBo) {

        String jsonBody = JsonLUtils.toJSon(delayBaseBo.getDelayMqSub());
        log.info("shardingKey = {},tag = {},jsonBody = {}", delayBaseBo.getShardingKey(), delayBaseBo.getTag(), jsonBody);

        // 发送消息,只要不抛异常就是成功
        try {
            Message msg = new Message(
                    // Message所属的Topic
                    rocketMqDelayProperties.getTopic(),
                    // Message Tag 可理解为Gmail中的标签,对消息进行再归类,方便Consumer指定过滤条件在MQ服务器过滤
                    delayBaseBo.getTag(),
                    // msg key  一般为业务主键
                    delayBaseBo.getShardingKey(),
                    // Message Body 可以是任何二进制形式的数据, MQ不做任何干预
                    // 需要Producer与Consumer协商好一致的序列化和反序列化方式
                    jsonBody.getBytes()
            );
            msg.setStartDeliverTime(LocalDateLUtils.getEpochMilli(delayBaseBo.getDelayTime()));
            SendResult sendResult = delayOrderProducerBean.send(msg, delayBaseBo.getShardingKey());
            assert sendResult != null;
            log.info("event消息发送成功,topic = {},key = {},messageId = {}", sendResult.getTopic(), delayBaseBo.getShardingKey(), sendResult.getMessageId());
        } catch (ONSClientException e) {
            //日志记录错误信息与入参信息
            log.error("event消息发送失败,shardingKey = {} ,jsonBody = {} , 异常信息:", delayBaseBo.getShardingKey(), jsonBody, e);
        }
    }

可以看到,延迟发送消息和实时发送消息的方法差不多,只不过多了一个msg.setStartDeliverTime()参数。

相关推荐
三水不滴16 小时前
Apache RocketMQ的原理与实践
经验分享·apache·rocketmq
pingzhuyan3 天前
linux运维-KylinV10的aarch64架构-docker微服务运维部署(全篇)
linux·docker·jdk·rocketmq·kylin·aarch64
短剑重铸之日3 天前
《SpringCloud实用版》Stream + RocketMQ 实现可靠消息 & 事务消息
后端·rocketmq·springcloud·消息中间件·事务消息
a程序小傲4 天前
得物Java面试被问:RocketMQ的消息轨迹追踪实现
java·linux·spring·面试·职场和发展·rocketmq·java-rocketmq
jiayong236 天前
MQ基础概念面试题
java·kafka·rabbitmq·rocketmq
短剑重铸之日9 天前
《RocketMQ研读》面试篇
java·后端·面试·职场和发展·rocketmq
时艰.9 天前
RocketMQ 面试核心知识点总结
面试·rocketmq
观测云9 天前
阿里云 RocketMQ 4.0 可观测最佳实践
阿里云·云计算·rocketmq
xiaolyuh1239 天前
Kafka、RocketMQ、RabbitMQ 事务消息核心差异对比
kafka·rabbitmq·rocketmq
星辰_mya9 天前
超时未支付订单之分库分表+定时任务+RMQ延时消息
java·架构·rocketmq