看了一圈找了一圈,感觉找到的都很复杂,不适合我这个java新手学习,所以把自己配置的代码贴上来。希望大家一起讨论。
如果大家有阿里云云服务的问题,也欢迎咨询和讨论。
1阿里云开通rocketmq,创建实例,创建topic,添加group
此过程在阿里云控制台操作,不做具体描述。
2 springboot项目中添加依赖
项目中已经依赖了大量阿里云相关package,只是新增了两个rocketmq相关的依赖,所有不确定是否还需要其他的package。
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>2.0.3</version>
</dependency>
<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-client</artifactId>
<version>4.5.1</version>
</dependency>
3 yml文件中,增加
rocketmq:
name-server: http://**********************-internet.aliyuncs.com:80
这个是tcp的地址,阿里云还提供了一个http的,用tcp的测试过了,http的就没有测试
4 订阅类
@Service
@RocketMQMessageListener(topic = "阿里云topic", consumerGroup = "阿里云group", accessKey = "阿里云arm已授权的accessKey", secretKey = "阿里云arm已授权的secretKey ")
class PayConsumer : RocketMQListener<MessageExt>, RocketMQPushConsumerLifecycleListener {
override fun onMessage(message: MessageExt?) {
System.out.printf("------- MessageExtConsumer msgId: %s, body:%s \n", message?.msgId, String(message?.body!!))
}
override fun prepareStart(consumer: DefaultMQPushConsumer?) {
// set consumer consume message from now
consumer?.consumeFromWhere = ConsumeFromWhere.CONSUME_FROM_TIMESTAMP
consumer?.consumeTimestamp = UtilAll.timeMillisToHumanString3(System.currentTimeMillis())
}
}
RUN
5 测试
在阿里云控制台,消息队列rocketmq>topic管理,找到自己的topic,
点击发送消息,输入测试数据
点击确定后,idea控制台出现
msgID是消息ID,可以看到输出的body是刚才输入body数据,说明rocketmq配置成功。
一个java新手的独自踩坑之路