RabbitMQ的死信队列解读

发布于:2024-10-24 编辑:匿名 来源:网络

基本介绍了什么是死信开关。定义业务队列时,必须考虑指定死信开关。

死信交换机可以绑定到任意普通队列,然后出现在业务队列中。当发生死信时,数据将被发送到死信队列。

什么是死信队列?死信队列其实就是一个普通的队列,只不过这个队列绑定了一个死信交换器,用来存储死信。 RabbitMQ中有一个交换叫DLX,全称为Dead-Letter-Exchange。

,可以称为死信交换器。当消息在队列中成为死消息时,它将被重新发送到另一个交换器。

这个交易所是DLX。绑定到DLX的队列称为死信队列。

需要说明的是,DLX也是一个普通的交换机,和一般的交换机没有什么区别。可以在任何队列上指定,它实际上设置了某个队列的属性。

当这个队列中出现死信时,RabbitMQ会自动将消息重新发布到设定的DLX上,然后路由到另一个队列,即死信队列。当消息进入死信队列时,消息过期代码语言:javascript copy MessageProperties messageProperties=new MessageProperties();//设置这条消息的过期时间为10秒 messageProperties.setExpiration("0");队列过期代码语言:javascript Copy Map arguments =new HashMap<>(); //指定死信交换并设置arguments.put("x-dead-letter-exchange",EXCHANGE_DLX); //设置死信路由key,value为死信开关和死信队列绑定的keyarguments.put("x-dead-letter-routing-key",BINDING_DLX_KEY); //队列的过期时间arguments.put( "x-message-ttl",0);return new Queue(QUEUE_NORMAL,true,false,false,arguments); TTL:Time to Live 的缩写,过期时间队列达到最大长度(最先排队的消息将被发送到 DLX) 代码语言:javascript copy Map Arguments = new HashMap( );//设置队列的最大长度,相反的消息会被挤出,成为坏信arguments.put("x -max-length", 5);消费者拒绝消息,从普通队列接收消息,不重新投递,但不确认消息,也不重新投递消息。

此时,消息进入死信队列。application.yml 启动手动确认代码 language: javascript copy spring:rabbitmq:listener: simple:acknowledge-mode:manual code language: javascript copy /** * 正在监听正常的队列名称,不是死信queue * 我们从普通队列接收消息,但不确认消息,也不重新投递消息。

此时消息进入死信队列* *通道消息通道(是一个连接下的消息通道,一个连接下有多个消息信息,发送/接收消息都是通过通道完成的) */ @RabbitListener( queues = {RabbitConfig.QUEUE}) public void process(Message message, Channel channel) { System.out.println("收到消息:" + message); //不确认消息,ack这个词的意思是确认 try { System.out.println("deliveryTag = " + message.getMessageProperties().getDeliveryTag()); //手动启用rabbitm消息消费确认模式然后编写这样的代码; Channel.basicNack(message.getMessageProperties().getDeliveryTag(), false, false); } catch (IOException e) { e.printStackTrace(); void basicNack(long DeliveryTag, boolean multiple, boolean requeue) DeliveryTag:消息的数字标签 multiple:翻译成中文就是多个,如果为true则表示对于所有小于 DeliveryTag 标签的消息,不会确认 Nack。 False 表示只有带有当前的deliveryTag 标签的消息才会被Nacked。

Requeue:如果为true,表示消息被Nacked后会重新发送到队列中。如果为 false,则消息被 Nacked 后不会重发。

发送给队列消费者拒绝消息,开启手动确认模式,拒绝消息而不重新投递,则进入死信队列 代码语言:javascript copy /** * 正常监听的队列名称,不是死信队列 * 我们从普通队列接收消息,但不确认消息,也不重新投递消息。此时消息进入死信队列**通道消息通道(是连接下的消息通道,一个连接下有多个消息信息,发送/接收消息都是通过通道完成的)*/ @RabbitListener(queues) = {RabbitConfig.QUEUE}) public void process(Message message, Channel channel) { System.out.println("收到消息:" + message);尝试 { System.out.println("deliveryTag = " + message.getMessageProperties().getDeliveryTag()); //要开启rabbitm消息消费的手动确认模式,那么代码是这样写的; Channel.basicReject(message.getMessageProperties().getDeliveryTag(), false); } catch (IOException e) { e.printStackTrace(); Channel.basicReject(message.getMessageProperties().getDeliveryTag(), true); basicReject 为负数 一般在消费消息发生异常时执行投递。

可以丢弃消息或者重新排序来重新处理消息 参数 1:消费者消息的索引参数 2:处理异常消息,true 表示重新排序,false 表示丢弃 Reject 拒绝消息时,可以使用 requeue 标志来告诉 RabbitMQ 是否需要重新发送给其他消费者。如果为false,则不会重发,一般消息会被RabbitMQ丢弃。

拒绝一次只能拒绝一封邮件。如果为 true,则消息将被重新传送。

Nack 与 Reject 类似,只不过它可以一次拒绝多条消息。您还可以使用重新排队标志,它是 AMQP 规范的 RabbitMQ 扩展。

通过RejectRequeuConsumer可以看到,无论是使用Reject方法还是Nack方法,当requeue参数设置为true时,都会重新投递消息。当 requeue 参数设置为 false 时,消息将丢失。

Springboot代码实战架构编辑如上图。消息到达正常交换机exchange.nomal.a。

通过绑定到普通队列queue.noaml.a,消息将到达普通队列。如果消息死了,稍后会转发。

到与普通队列绑定的死信交换机,死信交换机会将其转发到与其绑定的死信队列queue.deal.a。项目概述 项目采用springboot架构,主要用到的依赖有: 代码语言:javascript copy org.springframework.boot spring-boot -starter-amqp org.projectlombok lombok application.yml 配置文件如下: 代码语言:javascript复制服务器:端口:spring:rabbitmq:主机:..70。

端口: 用户名: admin 密码: 56 虚拟主机: /RabbitConfigDeal 配置类: 创建队列和交换机并绑定它们 代码语言: javascript copy @Configurationpublic class RabbitConfigDeal {} create 普通交换机 代码语言: javascript copy @Bean public DirectExchange normalExchange() { return ExchangeBuilder.directExchange("exchange.normal.a").build();创建死信开关代码语言: javascript copy @Bean public DirectExchange deadExchange() { return ExchangeBuilder.directExchange("exchange.dead.a").build(); } 创建死信队列 代码语言:javascript copy @Bean public Queue deadQueue(){ return QueueBuilder.durable("queue.dead.a").build() ;创建一个普通队列,设置其绑定的死信开关,以及对应的绑定路由键为命令码语言: javascript copy @Bean public Queue normalQueue(){ Map argument =new HashMap<>( );参数.put("x-message-ttl",0); argument.put("x-dead-letter-exchange","exchange.dead.a"); argument.put("x-dead-letter-routing-key","order"); return QueueBuilder.durable("queue.normal.a") .withArguments(arguments).build();绑定普通交换机和普通队列代码语言: javascript copy @Bean public Binding bindingNormal(DirectExchange normalExchange,Queue normalQueue){ return BindingBuilder.bind(normalQueue).to(normalExchange).with("order");绑定死信交换和死信队列代码语言:javascript copy @Bean public BindingbindingDeal(DirectExchange deadExchange,Queue deadQueue){ return BindingBuilder.bind(deadQueue).to(deadExchange).with("order"); } }MessageService业务类:发送消息和接收消息 代码语言:javascript copy @Component@Slf4jpublic class MessageService { @Resource private RabbitTemplaterabbitTemplate;} 发送消息方法代码语言:javascript copy public void sendMsg(){ //添加消息属性 Message message = MessageBuilder.withBody("你好词!".getBytes(StandardCharsets.UTF_8)) .build( ); rabbitTemplate.convertAndSend("exchange.normal.a","订单",message); log.info("消息发送时间:{}", new Date());这里使用的路由key是info MessageConvert涉及到应用程序序列化对于网络传输是不可避免的。发送端按照一定的规则将消息转换为字节数组进行发送,接收端按照约定的规则对byte[]数组进行解析。

RabbitMQ的序列化是指Message的body属性,也就是我们真正需要传输的东西,RabbitMQ抽象了一个MessageConvert接口来处理消息的序列化。其实有SimpleMessageConverter(默认)、Jackson2JsonMessageConverter等接受消息代码语言: javascript copy @RabbitListener(queues = {"queue.dead.a"}) public void receiveMsg(Message message){ byte[] body = message.getBody(); String queue = message.getMessageProperties().getConsumerQueue(); String msg=new String(body); log.info ("{}收到消息时间:{},消息为{}",queue,new Date(),msg); } Message 在消息传递过程中,实际传递的对象是 org.springframework.amqp.core .Message,主要由两部分组成: MessageProperties // 消息属性 byte[] body // 消息内容 @RabbitListener 使用@RabbitListener 注解来标记该方法,当调试队列中有消息时,就会接收并处理消息处理。

方法中的参数通过MessageConverter进行转换,如果使用自定义的MessageConverter,则需要在RabbitListenerContainerFactory实例中设置消息的content_type属性(Spring默认使用的是SimpleRabbitListenerContainerFactory)。身体数据被存储。

除了使用Message对象接收消息(包括消息属性等信息)之外,还可以直接使用对应的类型接收消息体内容,但如果方法参数类型不正确,会抛出异常: application/octet-stream:二进制字节数组存储,使用byte[]application/ x-java-serialized-object:Java对象序列化格式存储,使用Object和对应的类型(反序列化时类型应与包同名,否则会抛出类未找到异常)text/plain:文本数据类型存储,使用Stringapplication/json:JSON格式,使用Object,对应类型启动Animal class RabbitMq01Application:实现ApplicationRunner接口代码语言:javascript copy/** * @author 风清云丹*/@SpringBootApplicationpublic class RabbitMq01Application Implements ApplicationRunner { public static void main(String[] args) { SpringApplication.run(RabbitMq01Application.class ,参数); @Resource 私有 MessageService 消息服务; /** * 程序启动时就会调用该方法* @param args * @throws Exception */ @Override public void run(ApplicationArguments args) throws Exception { messageService.sendMsg();在SpringBoot中,提供了一个接口:ApplicationRunner。在这个界面中,只有一个run方法。

它的执行时机是:spring容器启动后,会立即执行该接口实现类的run方法。由于该方法是在容器启动后执行的,因此可以从spring容器中获取其他注入的bean。

启动主启动类后查看控制台:代码语言:javascript 复制09-28 10:46:17。 INFO 0 --- [main] c.e.rabbitmq01.service.MessageService:发送消息时间:Thu Sep 28 10:46:17 CST 09-28 10:46:37。

INFO 0 --- [ntContainer#0-1] c.e.rabbitmq01.service.MessageService:queue.dead.a 收到消息时间: 9 月 28 日星期四 10:46:37 CST,消息 问候语!这里我们可以看到消息是在17s发送的。 20s后,即37s时,我们收到了死信队列queue.dead.a中的消息。

?????????????????????????????我参加腾讯科技创造特训营第二期有奖征文比赛瓜分奖金池10000元和键盘手表一块。

RabbitMQ的死信队列解读

站长声明

版权声明:本文内容由互联网用户自发贡献,本站不拥有所有权,不承担相关法律责任。如果发现本站有涉嫌抄袭的内容,欢迎发送邮件 举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。

标签:

相关文章

  • 新规实施:申请手机号码将全面实行人脸比对

    新规实施:申请手机号码将全面实行人脸比对

    雷锋网消息,2020年12月2日,根据工信部此前发布的相关规定,自12月起1、2020年,电信企业必须在物理渠道全面落实肖像比对技术措施。 只有画像一致才能完成入网手续。 而且,自即日起,电信公司自有营业厅必须向用户提供查询其名下手机号码的服务,对用户有异议的手机号码应立

    06-18

  • 北京石景山区设立现代创新产业基金,总规模为30亿元

    北京石景山区设立现代创新产业基金,总规模为30亿元

    北京市石景山区设立总规模30亿元的现代创新产业基金。 据投资界7月6日消息,石景山区宣布设立总规模30亿元的现代创新产业基金。 通过科学引导,推动区域内以科技服务、数字创意、新一代信息技术为特色的现代金融主导产业发展,支持“1”高精尖产业发展,生态环保、城市更新等

    06-18

  • 打造企业级RPA平台,UiPath获2.25亿美元E轮融资

    打造企业级RPA平台,UiPath获2.25亿美元E轮融资

    投资圈(ID:pedaily)7月15日消息,据36氪报道,企业级RPA软件公司UiPath宣布,已完成2.25亿美元E轮融资。 由 Alkeon Capital Management 领投,投资者包括 Accel、Coatue、Dragoneer、IVP、Madrona Venture Group、红杉资本、腾讯投资、Tiger Global 和 Wellington。 本轮融

    06-18

  • 博姿科技专访创始人与李忠双:重新定义工业机器人,为先进制造做出贡献 -看到新势力NO. 108

    博姿科技专访创始人与李忠双:重新定义工业机器人,为先进制造做出贡献 -看到新势力NO. 108

    在人类发展史上,生产力更替是人类社会不断进步的支柱。 随着人工智能等先进技术的广泛应用,第四次工业革命的号角已经吹响。 同时,当前消费者对个性化产品的需求强烈,导致生产需要从大批量同质化转向小批量、多品种柔性生产。 新一轮工业革命,制造业生产线升级势在必行,

    06-18

  • 为让北美年轻人住上长租公寓,Tripalink获得3000万美元B+轮融资

    为让北美年轻人住上长租公寓,Tripalink获得3000万美元B+轮融资

    据投资界(ID:pedaily)11月5日消息,据36氪报道,Tripalink北美青年长租公寓品牌完成3000万美元B+轮融资,由Conductive Ventures和Altos Ventures共同领投,Assurant Ventures、Calin SJG Fund、K2VC、Tekton跟投风险投资。 Preferred Bank也参与了本轮投资。 截至目前,T

    06-18

  • 华控基金董事长张扬入选2020年投资行业百强投资人

    华控基金董事长张扬入选2020年投资行业百强投资人

    8月12日,《投资界》公布了中国权威人物评选的“投资行业最佳投资人”名单。 华琼基金的创始人、董事长张扬榜上有名。 人物名单。 “投资行业杰出投资人”投资者榜评选已连续五年举办。 自正式启动以来,今年的评选吸引了数千名早期投资人、VC、PE和战略投资者的积极参与。 投

    06-17

  • Kyligence完成7000万美元D轮融资,红点、顺为等参与,

    Kyligence完成7000万美元D轮融资,红点、顺为等参与,

    3月21日,Kyligence(上海久智信息科技有限公司)宣布完成7000万美元D轮融资。 本轮融资由浦发国际领投,中金资本旗下基金、歌斐资管、国方资本、ASG、鸿兆基金、浦信资本及原股东红点中国、耀明资本、顺为资本等跟投。

    06-18

  • 什么值得买?七夕最佳购物指南:四招而已

    什么值得买?七夕最佳购物指南:四招而已

    如何庆祝七夕肯定是大家最近最困扰的问题。 怎样才能有意义、划算、深刻呢?作为中国第一智能手机品牌,vivo推出了七夕最强策略。 只需四招,瞬间让你成为最强七夕达人!点击领取最佳礼物——终极品遇终极促销 3GB存储版vivo X5Max+、全球首款2K屏顶级旗舰vivo Xplay3S、只剩

    06-17

  • 听歌、识别歌曲的工具Shazam推出了Chrome插件,但还不够完善

    听歌、识别歌曲的工具Shazam推出了Chrome插件,但还不够完善

    自从2017年Shazam被苹果收购后,它就成为了苹果旗下的免费服务。 它以 Apple Music 为后盾,内置数万首歌曲。 在iPhone和iPad的控制中心,Mac用户如果想用它来识别歌曲,需要先安装软件,但无论如何,Shazam是寄生在苹果身上的,至少他们不用再担心盈利模式了。 近日,Shazam

    06-21

  • 转转:2020年转转集团服务GMV增长111%,集团收入同比增长229%

    转转:2020年转转集团服务GMV增长111%,集团收入同比增长229%

    今天,转转集团发布《年度二手交易服务白皮书》。 数据显示,转转集团服务GMV同比增长111%,集团营收同比增长229%。 生长%; 3C数码B2C业务支付订单量同比增长0.2%;全年机检服务订单量同比增长0.04%。

    06-18

  • 首次发布 -国药齿科完成A轮融资,华兴资本领投

    首次发布 -国药齿科完成A轮融资,华兴资本领投

    投资界(ID:pedaily)据2月9日消息,中国齿科中游整合+创新的新生力量国药齿科宣布完成A轮融资。 本轮融资由华兴资本旗下华兴新经济基金领投,德通资本跟投。 华兴资本担任本轮融资独家投资方。 完成新一轮融资后,国药齿科将加大中游渠道整合投入,打造中国DSO模式下的业务

    06-17

  • 多位高管参与揭秘字节AI领地之战

    多位高管参与揭秘字节AI领地之战

    Tech星球*了解到,字节旗下多个部门加大了AI产品研发投入,成果已陆续落地,其中包括抖音电商、海量引擎等业务部门,其中最为活跃的Flow部门不仅会推出豆袋、按钮等AI产品,还将推出AI角色互动APP“Talking Room”和一款可能是图片的AI产品“PicPic”。 另据消息,人士透露,

    06-18