RabbitMQ(Direct 订阅模型-路由模式)的使用

RabbitMQ(Direct 订阅模型-路由模式)

一,Direct 订阅模型-路由模式介绍(Routing)

​ 订阅模型-路由模式,此时生产者发送消息时需要指定 RoutingKey,即路由 Key,Exchange 接收到消息时转发到与 RoutingKey 相匹配的队列中。

​ direct的意思是直接的,direct类型的Exchange会将消息转发到指定Routing key的Queue上,Routing key的解析规则为精确匹配。也就是只有当producer发送的消息的Routing key与某个Binding key相等时,消息才会被分发到对应的Queue上。
路由模式:
在这里插入图片描述

1、每个消费者监听自己的队列,并且设置routingkey;

2、生产者将消息发给交换机,由交换机根据routingkey来转发消息到指定的队列;

应用场景:用户通知,当用户充值成功或转账完成系统通知用户,通知方式有短信、邮件多种方法,

二,使用

1.添加依赖

<!--引入rabbitMQ的依赖-->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

2.修改配置文件

  rabbitmq:host: 192.168.193.131publisher-confirm-type: correlated  #开启异步消息确认publisher-returns: true #开启publisher-return的机制template:mandatory: true  #消息路由失败,调用ReturnCallbacklistener:simple:  #消息监听器的一种简单配置方式retry:enabled: true # 开启消费者失败重试initial-interval: 1000 # 初识的失败等待时长为1秒multiplier: 1 # 失败的等待时长倍数,下次等待时长 = multiplier * last-intervalmax-attempts: 3 # 最大重试次数stateless: true # true无状态;false有状态。如果业务中包含事务,这里改为falseacknowledge-mode: manualdirect: #特定的消息监听器配置类型或者是指定一个直连型的交换机),用于消息的路由和分发retry:enabled: true # 开启消费者失败重试initial-interval: 1000 # 初识的失败等待时长为1秒multiplier: 1 # 失败的等待时长倍数,下次等待时长 = multiplier * last-intervalmax-attempts: 3 # 最大重试次数stateless: true # true无状态;false有状态。如果业务中包含事务,这里改为falseacknowledge-mode: manual #手动确认接收到的消息

3.创建配置类

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.DirectExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** @Description:rabbitMQ配置类 会在应用启动时被加载。* @bean  :用于指示一个方法将会产生一个 bean 对象,并添加到 Spring 容器中。*/
@Configuration
public class MyRabbitMQConfig {/*** @Description:创建一个名为 "loginQueue" 的 RabbitMQ 队列。* 参数 true 表示这个队列是持久化的,这意味着在 RabbitMQ 服务器重启后,这个队列仍然会存在,以保证消息不丢失*/@Beanpublic Queue loginQueue(){/*第一个参数为队列的名称 第二个参数为true 表示队列持久化 保障消息不丢失*/return new Queue("loginQueue",true);}/*** @Description:方法用于创建一个名为 "directExchange" 的 Direct Exchange(直连交换机)。* Direct Exchange 是 RabbitMQ 中一种简单的交换机类型,它会根据消息的 routing key 将消息路由到相应的队列*/@Beanpublic DirectExchange directExchange(){return new DirectExchange("directExchange");}/*** @Description:创建一个绑定,将之前创建的 "loginQueue" 队列绑定到 "directExchange" 交换机上,并且指定 routing key 为 "login"     */@Beanpublic Binding loginQueueBinding(){return BindingBuilder.bind(loginQueue()).to(directExchange()).with("login");}}

4.注入RabbitMQ模版引擎

//RabbitTemplate是Spring AMQP项目中的一个关键组件,用于在应用程序和RabbitMQ消息代理之间发送和接收消息。
@Autowired
private RabbitTemplate rabbitTemplate;

5.消息的发送

//记录登陆日志 记录到RabbitMQ
//定义消息的唯一ID 防止消息重复消费
String msgId = "msg-" + UUID.randomUUID().toString();
//定义消息内容
String msgBody = JSON.toJSONString(tbUser);//将消息唯一表示存入redis缓存  防止消息重复消费
stringRedisTemplate.opsForValue().set(msgId, msgBody);/*组装消息体 发送消息队列*/
MessageVO messageVO = new MessageVO();
messageVO.setMsgID(msgId);
messageVO.setMsgBody(msgBody);/*convertAndSend: 这是RabbitTemplate提供的一个方法,用于将消息转换并发送到RabbitMQ队列或交换机。"directExchange": 这是消息要发送到的目标交换机的名称。在RabbitMQ中,交换机是消息的分发中心,它根据特定的路由规则将消息发送到一个或多个队列。"login": 这是消息的路由键  routing key 。在直接交换机模式下,消息的路由键与队列的绑定键一致时,消息会被发送到该队列。JSON.toJSONString(messageVO): 这是要发送的消息内容。在这里,messageVO对象被转换成JSON格式的字符串,然后作为消息发送到RabbitMQ。这行代码的作用是将一个消息发送到名为directExchange的交换机,并且路由键为login,消息内容为messageVO对象的JSON字符串表示。*/
rabbitTemplate.convertAndSend("directExchange", "login", JSON.toJSONString(messageVO));

6.消息的接收(监听)

/*** @param (org.springframework.amqp.core.Message)message :RabbitMQ 消息的对象,包含消息体和消息属性等信息。* @param(com.rabbitmq.client.Channel;)channel:RabbitMQ 的通道,用于手动确认消息消费。* @return void* @date 2024/5/24 19:59* @Description: TODO* @RabbitListener 注解:主要用于消费名为 "loginQueue" 的队列中的消息。** @RabbitListener(queues = "loginQueue"):这个注解用于声明一个 RabbitMQ 消息监听器,* 它会监听名为 "loginQueue" 的队列,一旦有消息到达这个队列,就会触发 recvLogMessage 方法进行消费。*/@RabbitListener(queues = "loginQueue")public void recvLogMessage(Message message, Channel channel) {try {//-- 接收消息  获取消息体,然后使用 JSON 解析成 MessageVo 对象String s = new String(message.getBody());MessageVO messageVO = JSON.parseObject(s, MessageVO.class);System.out.println("RabbitMQ 收到消息:" + messageVO.getMsgID());//-- 判断消息重复消费String msgId = messageVO.getMsgID();if (!stringRedisTemplate.hasKey(msgId)) {// 消息已经消费过了,删除消息System.out.println("RabbitMQ 消息重复了:" + messageVO.getMsgID());// channel: 这是一个通道对象,用于与消息队列服务进行通信。通常在消息队列框架中,你需要首先建立一个通道(channel),然后通过这个通道发送、接收消息等操作。// basicAck: 这是一个确认消息的方法。在消息队列中,消费者(consumer)收到消息后,需要向消息队列服务确认(acknowledge)已经成功处理了这条消息,以便消息队列服务可以将这条消息标记为已处理。basicAck就是用来进行这个确认操作的方法。// message.getMessageProperties().getDeliveryTag(): 这部分代码用于获取消息的交付标签(delivery tag)。消息队列服务在向消费者传递消息时,会给每条消息分配一个唯一的标识符,即交付标签。消费者收到消息后,可以通过这个标签来确认消息。// true: 这个参数表示是否批量确认。如果设置为true,表示确认当前标签之前的所有未确认消息;如果设置为false,则仅确认当前标签所代表的消息。// 综合起来,这行代码的作用是:使用给定的通道对象(channel)对收到的消息进行确认,确认方式是通过交付标签(delivery tag)来指定。channel.basicAck(message.getMessageProperties().getDeliveryTag(), true);return;}                                                //-- 消费消息TbUser tbUser = JSON.parseObject(messageVO.getMsgBody(), TbUser.class);TbLog tbLog = new TbLog();tbLog.setCreateTime(new Date());tbLog.setLogContent(messageVO.getMsgBody());tbLogMapper.insert(tbLog);//-- 删除消息channel.basicAck(message.getMessageProperties().getDeliveryTag(), true);//-- 删除消息的唯一ID,防止重复消费stringRedisTemplate.delete(msgId);System.out.println("RabbitMQ 登录日志消息,消费成功了~~~~~~~~~~~~~~~~~~~~~~");} catch (IOException e) {System.out.println("登录日志接收失败了~~~~~~~~~~~~~~~~~~~~~");e.printStackTrace();}}

7.设置回调函数 和 确认回调

/*** @param* @return void* @date 2024/5/24 20:03* @Description: TODO 这是一个自定义方法名,用于初始化RabbitMQ相关设置。* @PostConstruct: 这是一个Spring注解,用于标记在bean初始化之后立即执行的方法。*/@PostConstructpublic void initRabbitMQ() {System.out.println("设置RabbitMQ消息回调,确保消息不丢失");//-- return 回调 : 消息发送失败了,会被调用/*当消息发送失败时,RabbitMQ会调用此回调函数。回调函数会重新发送消息*/rabbitTemplate.setReturnCallback(new RabbitTemplate.ReturnCallback() {/*returnedMessage 方法中,包含了以下四个参数:Message message:表示发送失败的消息对象,包含消息的内容和元数据。int replyCode:表示返回的错误码,用于指示消息发送失败的原因。String replyText:表示返回的错误信息,用于指示消息发送失败的具体描述。String exchange 和 String routingKey:分别表示发送消息时使用的交换机和路由键,用于指示消息发送的目的地。*/@Overridepublic void returnedMessage(Message message, int replyCode, String replyText, String exchange, String routingKey) {// 消息发送失败了,再次发送System.out.println("RabbitMQ 消息发送失败,再次发送");rabbitTemplate.convertAndSend(exchange, routingKey, message);}});//-- confirm 回调 : 消息发送无论成功还是失败,都会被回调//当消息发送成功或失败时,RabbitMQ都会调用此回调函数。回调函数会根据ack参数判断消息是否成功发送。rabbitTemplate.setConfirmCallback(new RabbitTemplate.ConfirmCallback() {/*CorrelationData correlationData:这个参数是用来关联生产者发送的消息和消息发送确认结果的数据对象。在发送消息时,可以通过 CorrelationData 设置一个唯一的标识符来关联消息,在确认时可以通过这个标识符来确定是哪条消息的确认结果。boolean ack:这个参数表示消息是否成功发送到 RabbitMQ 服务器并得到了确认。当 ack 为 true 时,表示消息发送成功;当 ack 为 false 时,表示消息发送失败。String cause:这个参数用来描述消息发送失败的原因。当 ack 为 false 时,cause 参数会包含失败的具体原因,可以用来进行日志记录或者错误处理。*/@Overridepublic void confirm(CorrelationData correlationData, boolean ack, String cause) {if (ack) {System.out.println("RabbitMQ 消息发送成功了");} else {System.out.println("RabbitMQ 消息发送失败了");}}});}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/21939.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

谁将决战上海滩,决定权在你手里

关注我们 - 数字罗塞塔计划 - 5月6日雨轩兰台的《【大比武01】AIGC赋能档案文创设计的尝试》&#xff0c;打响了“华夏伟业”杯第二届大比武活动的第一枪&#xff0c;截止到5月31日&#xff0c;入选的10篇优质内容已全部揭晓&#xff0c;好评如潮。感谢雨轩兰台、微柏软件、昀…

三种常见的报表模板,省时又方便

前言 在业务应用和数据分析中&#xff0c;报表是一种常见的数据展示形式&#xff0c;可以帮助用户更直观地理解和解读数据。然而&#xff0c;每次创建和设计一款报表都需要花费大量的时间和精力。为了提高报表设计的效率&#xff0c;本文小编以葡萄城公司的嵌入式BI工具——Wy…

webf 开发工具:数据库持久层基础文件生成工具

WZW.SqlMapHelpForJava是运行在.Net Framework4.0上的数据库持久层基础文件生成工具&#xff0c;支持多种关系型数据库的持久层基础文件、Java类的生成以及对配置文件的更新&#xff0c;与webf框架进行紧密配合&#xff0c;减少了数据库持久层基础文件编写工作量&#xff0c;提…

关于家储用防逆流电流互感器AKH-0.66/K K-φ16 100A/40mA详细介绍-安科瑞 蒋静

1.产品特点 产品外形美观&#xff0c;安装、接线方便&#xff0c;专用于通讯机房 100A 及以下配电系统改造&#xff0c;可与 AMC16 多回路监控仪表配合使用。 2.型号说明 3.外形尺寸(公差&#xff1a;2mm) 4.规格参数对照表 5.使用环境 &#xff08;1&#xff09;额定工作…

SPME2024开幕在即,深兰科技商用清洁机器人新品推介会蓄势待发

6月5日&#xff5e;7日&#xff0c;以“跨界融合洞见未来”为主题的“2024 SPME第六届上海国际物业管理产业博览会”(以下简称“物博会”)将在上海世博展览馆举行。应主办方邀请&#xff0c;深兰科技携多款AI清洁机器人亮相本届展会&#xff0c;向来自全球各地的观展企业家、经…

phpstudy配置的站点不能访问了

无法打开站点 打开网站的时候出现如下 没有人为主动去更改配置项&#xff0c;今天就不能正常访问了 检查了一遍配置&#xff0c;发现并无大碍&#xff0c;那就重新配置一遍看看 配置phpstudy 1、新建网站 2、选择项目入口文件夹 3、配置伪静态 4. 确认保存 在我的电脑 C:\…

Hive的常规操作

Hive常规操作 hive常用交互命令 -e执行sql语句 [rootmaster ~]# hive -e "show databases";-f执行sql脚本 [rootmaster ~]# hive -f /usr/local/demo.sql查看hive中输入的所有命令 [rootmaster ~]# cat ~/.hivehistory操作库 创建库 语法&#xff1a; create…

用贪心算法计算十进制数转二进制数(整数部分)

十进制整数转二进制数用什么方法&#xff1f;网上一搜&#xff0c;大部分答案都是用短除法&#xff0c;也就是除2反向取余法。这种方法是最基本最常用的&#xff0c;但是计算步骤多&#xff0c;还容易出错&#xff0c;那么还有没有其他更好的方法吗&#xff1f; 一、短除反向取…

关于WIN环境下pip DeepSpeed安装报错问题

问题描述 安装resemble-enhance项目时遇到的问题: >>> ERROR 1error: subprocess-exited-with-errorpython setup.py egg_info did not run successfully.exit code: 1[15 lines of output]test.cLINK : fatal error LNK1181: cannot open input file aio.libTraceb…

一维时间序列信号的基于小波集的时频超分辨率分析方法(Python)

由于小波变换只能反映信号的零维奇异性&#xff0c;即只能表达奇异点的位置和特性。事实上具有线奇异的函数在高维空间中非常普遍&#xff0c;例如&#xff0c;自然物体光滑边界使得自然图像的不连续性往往体现为光滑曲线上的奇异性&#xff0c;而并不仅仅是点奇异。对于一个二…

人工智能专业现代学徒制人才培养质量评价体系构建

一、 引 言 随着信息时代的发展&#xff0c;人工智能&#xff08;AI&#xff09;技术的飞跃进步对各行各业产生了深远影响&#xff0c;对专业人才的培养提出了更高要求。现代学徒制作为一种创新人才培养模式&#xff0c;通过校企合作&#xff0c;强调理论与实践的深度结合&…

性能测试学习-基本使用-元件组件介绍(二)

jmeter优点是&#xff1a;开源免费&#xff0c;小巧&#xff0c;丰富的学习资料和扩展组件 缺点是&#xff1a;1.不支持IP欺骗&#xff0c;分析和报表能力相对于LR欠缺精确度&#xff08;以分钟为单位&#xff09; 工具用户量分析报表IP欺骗费用体积扩展性Loadrunner多(万)精…

Lumière:开创性的视频生成模型及其应用

视频内容创造领域迎来了突破性进展&#xff0c;但视频生成模型由于运动引入的复杂性而面临更多挑战。这些挑战主要源自运动的引入所带来的复杂性。时间连贯性是视频生成中的关键要素&#xff0c;模型必须确保视频中的运动在时间上是连贯和平滑的&#xff0c;避免出现不自然的跳…

LVS精益价值管理系统 LVS.Web.ashx SQL注入漏洞复现

0x01 产品简介 LVS精益价值管理系统是杭州吉拉科技有限公司研发的一款专注于企业精益化管理和价值流优化的解决方案。该系统通过集成先进的数据分析工具、可视化的价值流映射技术和灵活的流程改善机制,帮助企业实现高效、低耗、高质量的生产和服务。 0x02 漏洞概述 LVS精益…

记录岁月云明细账excel导出的性能优化

财务软件报表还是非常麻烦&#xff0c;因为使用excel最好的就是财务&#xff0c;但是通过java导出excel&#xff0c;使用easyexcel不用报表工具&#xff0c;不是这么容易。采用jprofile对一个导出操作进行监控&#xff0c;其中一家零售企业导出当月全部明细账&#xff0c;检测到…

鬼刀画风扁平化粒子炫动引导页美化版

源码介绍 分享一款引导页,响应式布局&#xff0c;支持移动PC 添加背景图片&#xff0c;美化高斯模糊 &#xff0c;删除蒙版人物部分&#xff0c;更图片人物画风更美好 删除雪花特效 替换字体颜色 添加底备案号 预留友情连接 效果预览 源码下载 https://www.qqmu.com/3381.h…

‘yarn’不是内部或外部命令,也不是可运行的程序或批处理文件。

目录 问题点 解决方式 # 安装 # 版本 # 本地发生变化&#xff08;了解&#xff09; # 安装项目依赖 新问题 解决方式 问题点 在vscode中&#xff0c;点击dev运行&#xff0c;项目报错【Q1】 * 正在执行任务: yarn run dev yarn : 无法将“yarn”项识别为 cmdlet、函数…

AI生成PPT:一键式演示文稿制作的秘诀

工欲善其事&#xff0c;必先利其器。 随着AI技术与各个行业或细分场景的深度融合&#xff0c;日常工作可使用的AI工具呈现出井喷式发展的趋势&#xff0c;AI工具的类别也从最初的AI文本生成、AI绘画工具&#xff0c;逐渐扩展到AI思维导图工具、AI流程图工具、AI生成PPT工具、AI…

OrangePi Kunpeng Pro套装测评:开箱与基本功能测试

前言 大家好&#xff0c;我是起个网名真难。非常荣幸受到香橙派的邀请&#xff0c;同时也是第一次做这个事情&#xff0c;很荣幸对香橙派与华为鲲鹏在2024年5月12日联合发布的新品——香橙派Kunpeng Pro开发板进行深入的评测。这款开发板是香橙派与华为鲲鹏合作推出的高性能平…

中信建投证券信息技术部PMO高级经理张子洋受邀为第十三届中国PMO大会演讲嘉宾

全国PMO专业人士年度盛会 中信建投证券股份有限公司信息技术部PMO高级经理张子洋先生受邀为PMO评论主办的2024第十三届中国PMO大会演讲嘉宾&#xff0c;演讲议题为“浅谈项目管理标准化的建设及实践分享”。大会将于6月29-30日在北京举办&#xff0c;敬请关注&#xff01; 议题…