SpringBoot中如何使用RocketMQ
发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,这篇文章给大家分享的是有关SpringBoot中如何使用RocketMQ的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。接下来我们模拟一种场景:商品下单成功之后,向下单用户发
千家信息网最后更新 2024年11月19日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安全错误
数据库的锁怎样保障安全
小型数据库能耗是多少
linux部署服务器安全
android升级数据库
巨兽战场不同服务器可以一起玩吗
克而瑞物管数据库价格
中山专业软件开发批发价格
绍兴营销网络技术收费标准
科技互联网产品发布会
2018青少年网络安全事例
现代软件开发参考价格
软件开发专科生毕业好找工作吗
网络安全信息化建设的计划
饥荒进朋友服务器警告
执行sql语句数据库无响应
json客户端 服务器
河北定制网络技术服务哪个正规
阿里巴巴网络安全牛人
文件服务器架构图
土壤环境监测数据库系统
软件开发医疗
在服务器上搭建mqtt客户端
网络安全为主题的作文500
.net软件开发知识点
软件开发平台一般有什么
成都java直销软件开发
夜幕数据库
青岛的软件开发公司有哪些
服务器外网安全访问
空白web数据库
中兴通讯软件开发是双休吗