13、SpringCloud -- RocketMQ 消息发送和消费的实际应用

RocketMQ

准备工作:

清除MQ数据:

RocketMQ的数据应该是存在c盘的这个地方,可以把这些数据都清除掉,用来测试MQ是否执行符合期望。

在这里插入图片描述

启动MQ:

在这里插入图片描述

启动broker:

我是在bin 那里启动cmd的,所以 …/表示去到上一级找broker.conf,以后启动也可以在conf那边启动。不局限这个方法。

在这里插入图片描述

也可以这样启动
在这里插入图片描述

启动管控台:

这个官控台是一个springboot项目

在这里插入图片描述
在这里插入图片描述

启动这个jar包

在这里插入图片描述

启动成功

在这里插入图片描述

在这里插入图片描述
这个集群有显示这个才表示mq启动成功。

如果没显示出来,可能是broker启动不对。

在这里插入图片描述

在这里插入图片描述

项目应用:

准备工作:

添加依赖:

在seckill-server服务的pom文件里面添加mq的依赖
在这里插入图片描述

gitee 添加配置文件:

因为配置都在gitee上面,所以添加一个mq的yml配置文件

rocketmq:
  name-server: 127.0.0.1:9876
  producer:
    group:  SECKILL_ORDER_GROUP_PRODUCER 

如果后面用到的是linux的mq,就只需要把name-server的地址改成linux里面的mq地址就可以了。
在这里插入图片描述

yml:

gitee上面添加了mq的配置文件,这里要关联上mq的配置文件和依赖的话,需要在这里把这个mq的配置文件加上来,后面项目启动就会去到gitee上面把rocketmq-server文件拉下来用。

代码:

需求1:发送消息到MQ

将秒杀的请求消息发送到 MQ

前端:

在这里插入图片描述

后端:

在这里插入图片描述

封装的对象和常量
在这里插入图片描述

测试:

现在测试能否将秒杀数据发送到MQ

正在抢购中,没有之前的跳转到秒杀成功的页面,符合预期

在这里插入图片描述

测试前的主题:没有create_order主题
在这里插入图片描述

点击秒杀后就有了,符合预期
在这里插入图片描述

需求2:消费消息
后端:

启动服务后,就会自动执行onMessage方法,去消息列表里面进行消息消费
在这里插入图片描述
启动服务后,管控台也会自动出现这个消费组
在这里插入图片描述

测试:

全部数据刷新测试:

以这个2022-12-01 17:50:58时间的为主

秒杀这个商品
在这里插入图片描述

然后可以在主题这里看到这个消息
在这里插入图片描述

消费者这边看消费详情,也可以看到这个时间段的消费数据,发送消息时间和消费消息时间差不多,因为并发量不高。

在这里插入图片描述

可以看出执行成功了。
在这里插入图片描述

目前测试暂时正常,但测试太混乱,肯定有些数据是不正确的,后续再慢慢发现。

重新测试一次,发现是正常的可以正常发送消息和消费消息。

同步改异步:

同步发送消息改成异步发送消息

onSuccess 方法就是异步发送消息成功后需要写的业务逻辑

onException 方法就是异步发送消息失败后需要写的业务逻辑

目前还不知道该在这些方法里面写什么业务逻辑比较合理,目前看以来和同步发送消息没什么区别。后续待研究

在这里插入图片描述

这个是百度的:

同步发送消息改成异步发送消息,如图就可以了。

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_L_J_H_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值