RocketMQ发送延迟消息时报错,发送同步消息却正常

延时消息代码如下:

Message<Mdds> message = MessageBuilder.withPayload(mdds).build();
// 延迟第3级发送(延迟10秒)
rocketMQTemplate.syncSend(MessageConstant.TOPIC_ORDER, message, 1000, 3);

能正确调用的方法如下:

rocketMQTemplate.convertAndSend(MessageConstant.TOPIC_ORDER, mdds);

错误详情如下:

org.springframework.messaging.MessagingException: sendDefaultImpl call timeout; nested exception is org.apache.rocketmq.remoting.exception.RemotingTooMuchRequestException: sendDefaultImpl call timeout

解决方法:

设置的超时时间为3s以上,问题解决,代码如下:

rocketMQTemplate.syncSend(MessageConstant.TOPIC_ORDER, message, 3000, 3);

注意:网上很多错误方法,如修改配置文件broker.conf,并在mqbroker运行命令时增加参数 -c ../conf/broker.conf,并在mqnamesrv运行命令时增加-n 127.0.0.1:9876,这些解决不了问题!如果是配置错误,不可能成功发送同步的消息

我建了一个私域流量运营的社群,欢迎朋友们进群一起交流,想进群关注并私信我吧、