当前位置: 首页 > wzjs >正文

郑州做网站公司有多少品牌设计公司

郑州做网站公司有多少,品牌设计公司,仙游h5做网站,关于网站设计的书1. 简介 在前面的高级特性中,我们介绍了重试机制和 TTL,那么产生下列问题: 在重试机制中,当消费者消费消息发生异常时,会触发消息重发机制,由于我们配置了最大的重发次数,那么当超过这个次数后…

1. 简介

在前面的高级特性中,我们介绍了重试机制和 TTL,那么产生下列问题:

  • 在重试机制中,当消费者消费消息发生异常时,会触发消息重发机制,由于我们配置了最大的重发次数,那么当超过这个次数后,若消息依然没有被成功消费,就需要将消息进行保存,等待下一次消费,那么,这条消息应该保存到哪里去呢?
  • 在 TTL 机制中,我们为队列和消息设置了过期时间,当超过这个时间后消息就会被删除,但是这条消息是需要被消费的,于是就需要将过期的消息保存下来,等待下次消费。但是,消息应该保存到哪里去呢?

在 RabbitMQ 中,将类似于结果的消息称为死信,那么就涉及到,变成死信的消息应该存储到哪里去?

2. 会产生死信的场景

  • 消息重发后,次数到达指定重发次数依然未被消费,就会成为死信
  • 消息到达过期时间依然没有被消费,就会成为死信
  • 队列已经满了,却依然由消息入队列,就会产生溢出,溢出的这部分消息就会成为死信

3. 死信队列

在 RabbitMQ 中,可以声明一个队列,这个队列专门用来存放死信,于是就成为死信队列。

死信队列的工作流程如下:

  1. 首先需要声明一个死信交换机,与普通队列进行绑定;
  2. 其次需要声明一个死信队列,与死信交换机进行绑定;
  3. 当普通队列中的消息成为死信后,就会被发送给死信交换机,然后由死信交换机分配给与之绑定的死信队列;
  4. 存储在死信队列中的死信会等待被别的消费者再次消费。

4. 配置死信交换机与死信队列

声明一个正常交换机,正常队列,死信交换机,死信队列,并将正常交换机与正常队列进行绑定,将正常队列与死信交换机进行绑定,将死信交换机与死信队列进行绑定,代码如下:

@Configuration
public class DLConfig {/*** 正常* @return*/@Bean("norQueue")public Queue norQueue() {return QueueBuilder.durable(Constants.NOR_QUEUE).ttl(10000) //过期时间 10s.deadLetterExchange(Constants.DL_EXCHANGE) //绑定死信交换机.deadLetterRoutingKey(Constants.DL_ROUTINGKEY).maxLength(10L) //队列长度为 10.build();}@Bean("norExchange")public DirectExchange norExchange() {return ExchangeBuilder.directExchange(Constants.NOR_EXCHANGE).build();}@Bean("norBind")public Binding norBind(@Qualifier("norExchange") DirectExchange directExchange,@Qualifier("norQueue") Queue queue) {return BindingBuilder.bind(queue).to(directExchange).with(Constants.NOR_ROUTINGKEY);}/*** 死信*/@Bean("dlQueue")public Queue dlQueue() {return QueueBuilder.durable(Constants.DL_QUEUE).build();}@Bean("dlExchange")public DirectExchange dlExchange() {return ExchangeBuilder.directExchange(Constants.DL_EXCHANGE).build();}@Bean("dlBind")public Binding dlBind(@Qualifier("dlExchange") DirectExchange directExchange,@Qualifier("dlQueue") Queue queue) {return BindingBuilder.bind(queue).to(directExchange).with(Constants.DL_ROUTINGKEY);}
}

在上面的代码中,我们指定了下面的条件:

  • 队列的过期时间为 10s
  • 队列长度为 10 

重试机制的配置如下:

spring:rabbitmq:listener:simple:acknowledge-mode: autoretry:enabled: true # 开启消费者失败重试initial-interval: 5000ms # 初始失败等待时⻓为5秒max-attempts: 5 # 最⼤重试次数(包括自身消费的⼀次)

在上面的配置中,设置的最大的重发次数为 5 次。

5. 验证消息重试超过规定次数是否进入死信队列

生产者代码如下:

    @RequestMapping("/dl")public String dl() {String messageInfo = "dl... ";rabbitTemplate.convertAndSend(Constants.NOR_EXCHANGE, Constants.NOR_ROUTINGKEY, messageInfo);return "消息发送成功";}

消费者代码如下:

@Component
@Slf4j
public class DLListener {@RabbitListener(queues = Constants.NOR_QUEUE)public void listener(Message message) throws IOException {String messageInfo = new String(message.getBody());long deliveryTag = message.getMessageProperties().getDeliveryTag();log.info("接收消息, message: {}, deliveryTag: {}", messageInfo, deliveryTag);int num = 1 / 0;log.info("消息消费完成");}
}

代码运行结果如下:

 

消息重发五次后抛出异常,观察 RabbitMQ 客户端后,这条消息已经存放进了死信队列中:

  

6. 验证 TTL 与死信队列

生产者代码如下:

    @RequestMapping("/dl")public String dl() {String messageInfo = "dl... ";rabbitTemplate.convertAndSend(Constants.NOR_EXCHANGE, Constants.NOR_ROUTINGKEY, messageInfo);return "消息发送成功";}

将正常队列的 TTL 设置为 10s,运行代码后,观察 RabbitMQ 客户端:

10s 前:

10s 后:

 

7. 验证队列溢出与死信队列

将正常队列的长度设置为 10,生产者向 RabbitMQ 发送 20 条数据,生产者代码如下:

    @RequestMapping("/dl")public String dl() {for (int i = 0; i < 20; i++) {String messageInfo = "dl... " + i;rabbitTemplate.convertAndSend(Constants.NOR_EXCHANGE, Constants.NOR_ROUTINGKEY, messageInfo);}return "消息发送成功";}

运行代码,观察 RabbitMQ 客户端:

可以看到,溢出的 10 条消息进入了死信队列。 

http://www.dtcms.com/wzjs/131259.html

相关文章:

  • 公司网站建设设计方案桌面百度
  • 网站出现死链怎么办网络事件营销案例
  • 请问番禺哪里有做网站的seo经验
  • 网站后台建设内容株洲seo优化报价
  • 临沂网站制作定制建网站流程
  • 微信小程序怎么批量删掉seo常用优化技巧
  • 江苏省建设工程质量监督站网站培训机构seo
  • 搭建网站哪个好如何提高自己在百度的排名
  • 一站式手机网站制作百度官网认证价格
  • 网络平台创建需要多少钱网络营销seo优化
  • 曲阜做网站百度统计代码安装位置
  • 新的龙岗网站建设百度关键词热度查询
  • 十堰网站建设价格重庆百度seo代理
  • php做的网站预览世界杯大数据
  • 兰州模板网站建设佛山关键词排名工具
  • 200M电信宽带做网站网店运营
  • 怎么样给公司做网站互联网营销师是什么
  • wordpress文章页修改seo优化搜索结果
  • 先做网站还是先收集样品培训总结怎么写
  • 国外wordpress电影模板seo网站分析工具
  • 长春网站建设首选网诚传媒深圳seo技术
  • 用空间做网站如何做好安全搜索推广渠道有哪些
  • 网站建立于网页设计网络推广平台有哪些?
  • 淮北电子商务网站建设厦门seo排名优化公司
  • 模板网站怎么做做网络推广为什么会被抓
  • 北京seoqq群福州短视频seo公司
  • 税务门户网站建设成果整站优化cms
  • 做网站工资待遇如何做电商新手入门
  • 深圳跨境电商公司排名seo怎么做整站排名
  • 企业建设好一个网站后 如何进行网站推广大庆建站公司