阿里云RocketMQ消费MQTT消息

业务背景:

项目中涉及的消息队列既有RocketMQ,又有MQTT,均为阿里云提供(阿里云有专门的"微消息队列 MQTT 版"模块,但博主公司消息队列的实例都在"消息队列 RocketMQ 版"模块下,只是实例不同,猜测是做了适配,有清楚的大佬欢迎指点)。其中MQTT的消息是由硬件设备上报而来,由java服务进行消费,使用一套内部框架连接。现因框架存在适配问题,经讨论决定放弃使用,需改造原消费代码。

技术方案:

查询资料与询问同事得知两种消息队列在底层逻辑上高度相似,可以用RocketMQ方式连接MQTT的topic并消费。在实际改造过程中发现二者均可通过com.aliyun.openservices.ons.api.ONSFactory#createConsumer这一阿里云官方接口进行连接。而项目中已有一套配置用于连接RocketMQ,两类消息队列的地址、密钥等实例信息并不相同。因此改造的重点其实就是实现RocketMQ多实例配置。

代码实现:

java 复制代码
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * 自定义注解
 */
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface OnsMqttMessageListener {

    String topic();

    String consumerGroup();

}
java 复制代码
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.stereotype.Component;

/**
 * 参数类
 */
@Data
@Component
@EnableConfigurationProperties
@ConfigurationProperties(prefix = "aliyun.rocketmq")
public class OnsMqttMessageProperties {

    private String onsAddr;

    private String accessKey;

    private String secretKey;

    private String groupId;

}
java 复制代码
import com.aliyun.openservices.ons.api.Consumer;
import com.aliyun.openservices.ons.api.MessageListener;
import com.aliyun.openservices.ons.api.ONSFactory;
import com.aliyun.openservices.ons.api.PropertyKeyConst;
import com.geelytech.bms.annotation.OnsMqttMessageListener;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.context.event.ApplicationReadyEvent;
import org.springframework.context.ApplicationListener;
import org.springframework.core.annotation.AnnotationUtils;
import org.springframework.stereotype.Component;

import java.util.Map;
import java.util.Properties;

/**
 * 配置类
 */
@Slf4j
@Component
public class OnsMqttMessageConsumerConfig implements ApplicationListener<ApplicationReadyEvent> {

    @Autowired
    private OnsMqttMessageProperties onsMqttMessageProperties;

    /**
     * 注入所有MessageListener实例
     */
    @Autowired
    private Map<String, MessageListener> messageListeners;

    @Override
    public void onApplicationEvent(ApplicationReadyEvent event) {
        String onsAddr = onsMqttMessageProperties.getOnsAddr();
        String accessKey = onsMqttMessageProperties.getAccessKey();
        String secretKey = onsMqttMessageProperties.getSecretKey();
        log.info("ConsumerSubscriptionConfig onApplicationEvent messageListeners={}", messageListeners);

        // 订阅每个MessageListener
        for (Map.Entry<String, MessageListener> entry : messageListeners.entrySet()) {
            MessageListener listener = entry.getValue();

            OnsMqttMessageListener annotation = AnnotationUtils.findAnnotation(listener.getClass(), OnsMqttMessageListener.class);
            if (annotation != null) {
                String topic = annotation.topic();
                String consumerGroup = annotation.consumerGroup();

                Properties properties = new Properties();
                properties.setProperty(PropertyKeyConst.GROUP_ID, consumerGroup);
                properties.setProperty(PropertyKeyConst.NAMESRV_ADDR, onsAddr);
                properties.setProperty(PropertyKeyConst.AccessKey, accessKey);
                properties.setProperty(PropertyKeyConst.SecretKey, secretKey);

                Consumer consumer = ONSFactory.createConsumer(properties);
                consumer.subscribe(topic, "*", listener);
                consumer.start();
            }
        }
    }

}
java 复制代码
import com.aliyun.openservices.ons.api.Action;
import com.aliyun.openservices.ons.api.ConsumeContext;
import com.aliyun.openservices.ons.api.Message;
import com.aliyun.openservices.ons.api.MessageListener;
import com.geelytech.bms.annotation.OnsMqttMessageListener;
import com.geelytech.satellite.constant.TopicConstant;
import com.geelytech.satellite.dto.eventOriginalData.BizSwapDone;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import static com.aliyun.openservices.ons.api.Action.CommitMessage;

@Slf4j
@Component
@OnsMqttMessageListener(topic = "", consumerGroup = "")
public class BmsBizSwapDoneConsumer implements MessageListener {

    @Override
    public Action consume(Message message, ConsumeContext consumeContext) {
        // 业务逻辑
        return CommitMessage;
    }

}
相关推荐
风吹落叶花飘荡2 小时前
2026 在阿里云(Aliyun)上实现 Certbot 自动化申请
阿里云·自动化·云计算
EMQX6 小时前
大规模使用 AWS IoT Core 的成本困境:EMQX 如何削减 80% 开支
物联网·mqtt·云计算·aws
木子欢儿6 小时前
阿里云系统磁盘总读BPS突然增长很高,导致网站502 Bad Gateway
阿里云·云计算·gateway
予枫的编程笔记7 小时前
【Java进阶2】Java常用消息中间件深度解析:特性、架构与适用场景
java·kafka·rabbitmq·rocketmq·activemq
微爱帮监所写信寄信7 小时前
微爱帮技术实践:阿里云短信接口的高可用优化方案
开发语言·网络协议·阿里云·云计算·php
通义灵码21 小时前
从 Vibe Coding 到云端部署:Qoder + 阿里云 ECS 实战
阿里云·云计算
得物技术1 天前
RocketMQ高性能揭秘:承载万亿级流量的架构奥秘|得物技术
后端·rocketmq
星辰_mya1 天前
RocketMQ
java·rocketmq·java-rocketmq
摇滚侠1 天前
RocketMQ 教程丨深度掌握 MQ 消息中间件,rocketmq 安装,控制台,笔记 21-27
笔记·rocketmq·java-rocketmq
一叶飘零_sweeeet1 天前
2025 实战复盘:物联网 + 数据检索融合项目的核心技术实现与心得
java·物联网·mqtt