SpringBoot中如何使用RocketMQ
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,这篇文章给大家分享的是有关SpringBoot中如何使用RocketMQ的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。接下来我们模拟一种场景:商品下单成功之后,向下单用户发
千家信息网最后更新 2025年01月21日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安全错误
数据库的锁怎样保障安全
单片机软件开发用什么语言
如果软件开发像建造狗窝一样
乡镇网络安全周总结报告
网络安全面临的困难
信息技术教案《网络安全》
昆明互联网科技怎样
怀柔区好的软件开发设计
万润软件开发
网络安全需求的具体内容
网络安全辩论会
宣城市网络安全应急支撑单位
石景山区咨询软件开发优势
网络技术公司成立必要性
山东企业软件开发哪家实惠
青岛专业软件开发中心
互联网科技核心竞争力
游戏禁止未成年人深夜登录服务器
数据库的datetime
网络技术市值
房屋销售管理系统数据库单表查询
世界上最新的网络技术
csgo连不上完美服务器
怎么查询服务器是否连接外网
数据库表默认时间
数据库间接口
宿豫区直销网络技术市场
和龙软件开发哪家靠谱
网络安全保卫支队干嘛的
数据库技术数据库分离操作
四年级网络安全手抄报写什么