SpringBoot中如何使用RocketMQ
发表于:2025-11-10 作者:千家信息网编辑
千家信息网最后更新 2025年11月10日,这篇文章给大家分享的是有关SpringBoot中如何使用RocketMQ的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。接下来我们模拟一种场景:商品下单成功之后,向下单用户发
千家信息网最后更新 2025年11月10日SpringBoot中如何使用RocketMQ
这篇文章给大家分享的是有关SpringBoot中如何使用RocketMQ的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
接下来我们模拟一种场景:商品下单成功之后,向下单用户发送短信。以此来示例SpringBoot中RocketMQ的使用方式。

1 订单微服务发送消息
1.1 订单微服务添加rocketmq的依赖
org.apache.rocketmq rocketmq-spring-boot-starter 2.1.1 org.apache.rocketmq rocketmq-client 4.7.1
1.2 添加配置
rocketmq: name-server: 192.168.232.129:9876 # rocketmq服务的地址 producer: group: jack-producer-group # 生产者组名
1.3 编写测试代码
package cn.jack.controller; import cn.jack.domain.Order;import cn.jack.domain.Product;import cn.jack.service.OrderService;import cn.jack.service.ProductService;import com.alibaba.fastjson.JSON;import lombok.extern.slf4j.Slf4j;import org.apache.rocketmq.spring.core.RocketMQTemplate;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.cloud.client.discovery.DiscoveryClient;import org.springframework.web.bind.annotation.PathVariable;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RestController;import org.springframework.web.client.RestTemplate; @RestController@Slf4jpublic class OrderController { @Autowired private RestTemplate restTemplate; @Autowired private OrderService orderService; @Autowired private DiscoveryClient discoveryClient; @Autowired private ProductService productService; @Autowired private RocketMQTemplate rocketMQTemplate; /** * 下单 -- 基于Feign实现服务调用 * @param pid 商品id * @return */ @RequestMapping("/order/prod/{pid}") public Order order(@PathVariable("pid") Long pid) { log.info("收到下单请求,准备查询商品信息。pid={}", pid); // 通过Feign调用商品微服务,查询商品信息 Product product = this.productService.findByPid(pid); log.info("商品信息查询成功。内容为:{}", JSON.toJSONString(product)); // 进行容错判断 if (product.getPid() == -100) { Order order = new Order(); order.setOid(-100L); order.setPname("下单失败"); return order; } // 生成商品信息保存 Order order = new Order(); order.setNumber(1); order.setPid(pid); order.setPname(product.getPname()); order.setPprice(product.getPprice()); order.setUid(1); order.setUsername("陈家宝"); this.orderService.createOrder(order); log.info("订单信息保存成功。内容为:{}", JSON.toJSONString(order)); // TODO 下单成功之后,mq发送订单内容消息 rocketMQTemplate.convertAndSend("jack-topic", order); return order; }}1.4 测试
访问下单接口,确认RocketMQ是否发送了消息。从RocketMQ控制台得到确认,消息发送成功。

2 用户微服务订阅消息
2.1 用户微服务增加rocketmq依赖
com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery org.apache.rocketmq rocketmq-spring-boot-starter 2.1.1 org.apache.rocketmq rocketmq-client 4.7.1
2.2 修改主类,启动nacos客户端
package cn.jack; import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @SpringBootApplication@EnableDiscoveryClientpublic class UserApplication { public static void main(String[] args) { SpringApplication.run(UserApplication.class); }}2.3 修改配置文件
rocketmq: name-server: 192.168.232.129:9876 # rocketmq服务的地址
2.4 编写消息接收服务
package cn.jack.service; import cn.jack.domain.Order;import lombok.extern.slf4j.Slf4j;import org.apache.rocketmq.spring.annotation.RocketMQMessageListener;import org.apache.rocketmq.spring.core.RocketMQListener;import org.springframework.stereotype.Service; @Slf4j@Service@RocketMQMessageListener(consumerGroup = "jack-consumer-group", topic = "jack-topic")public class SmsService implements RocketMQListener{ @Override public void onMessage(Order order) { log.info("收到订单信息,内容如下:{}, 接下来进行短信发送", order); }}
2.5 测试
启动用户微服务,收到了来自RocketMQ的消息。
2020-09-16 21:46:30.465 INFO [service-user,,,] 660 --- [MessageThread_2] cn.jack.service.SmsService : 收到订单信息,内容如下:Order(oid=66, uid=1, username=陈家宝, pid=2, pname=雪梨, pprice=2000.0, number=1), 接下来进行短信发送
2020-09-16 21:46:30.465 INFO [service-user,,,] 660 --- [MessageThread_1] cn.jack.service.SmsService : 收到订单信息,内容如下:Order(oid=65, uid=1, username=陈家宝, pid=3, pname=华为, pprice=8000.0, number=1), 接下来进行短信发送
消息成功消费:
感谢各位的阅读!关于"SpringBoot中如何使用RocketMQ"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
服务
信息
内容
消息
商品
订单
成功
接下来
短信
用户
短信发送
陈家
查询
测试
地址
更多
篇文章
配置
不错
实用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
红米3谷歌服务器
软件开发 技术可行性
虎眼科技软件开发制作
霹雳网络技术宣传片
软件开发公司如何加密
宜宾网络技术哪家强
海曙直销软件开发设计
派出所如何加强企业网络安全
教师数据库课程设计总结
网络安全服务系统代码
云南游戏服务器地址云主机
澄迈县网络安全信息
网络抓包 数据库
洛奇服务器启动管理
重庆超频服务器厂家供应
网络安全天才郑海为
网络技术中的端口含义
数据库bak1文件怎么打开
部落服务器2022年奥山战场
网络技术实训论述题
数据库中如何修改表中的列
苹果自家数据库
飞机的性能数据库
湖北网络安全工程信息推荐
黔江区综合软件开发流程参考价
网络安全基本设备图片
属于网络安全防护措施的是
湖南网络技术学院在哪里
在服务器上添加网站
网络安全小常识100条短5 6