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

高端网站建设网页设计百度入口的链接

高端网站建设网页设计,百度入口的链接,通过ip直连打开网站要怎么做,网站建设图片属性设置RabbitMQ延迟队列的实现 延迟消息是什么延迟消息的实现死信交换机代码实现 延迟消息插件 延迟消息是什么 延迟消息是将消息发送到MQ中,消费者不会立即收到消息,而是过一段时间之后才会收到消息,进行处理。在一些业务中,可以用到延…

RabbitMQ延迟队列的实现

  • 延迟消息是什么
    • 延迟消息的实现
    • 死信交换机
      • 代码实现
    • 延迟消息插件


延迟消息是什么

延迟消息是将消息发送到MQ中,消费者不会立即收到消息,而是过一段时间之后才会收到消息,进行处理。在一些业务中,可以用到延迟消息,比如我们在成功下单一个商品后,需要立即付款,为了避免商品库存一直被占有,我们会给商品设置一个支付时间,如果在这段时间没有支付成功,就会恢复库存,删除订单,对于订单支付的超时删除我们是通过延迟消息来实现的,让消费者在支付超时之后查询用户是否支付,如果支付成功直接返回,如果支付失败就恢复库存删除订单。

延迟消息的实现

延迟消息由以下两种方式实现,第一种是通过绑定死信交换机实现,第二种通过延迟消息插件实现,推荐使用第二种,更加简单

死信交换机

满足以下三种情况之一的叫做死信:
1、在设置了过期时间的消息,放入队列中,超过了过期时间没有被处理的消息
2、消息消费失败(返回nack或者reject)并且不能重复入队
3、队列消息堆积满了,最早的消息叫做死信
我们可以给队列绑定参数指定交换机,那么死信会被投递到指定交换机。
消息队列实现原理:我们可以设置一组没有消费者的交换机和队列,设置另一组处理绑定死信的交换机、队列和消费者,来处理延迟消息。

代码实现

定义死信交换机等和消费延迟消息交换机等:


@Configuration
public class DelayConfiguration {/*** 定义死信交换机、队列以及绑定*/@Beanpublic DirectExchange exchange() {return new DirectExchange("dead.direct");}@Beanpublic Queue queue() {Queue queue = new Queue("dead.queue");queue.addArgument("x-dead-letter-exchange", "delay.direct");return queue;}@Beanpublic Binding binding() {return BindingBuilder.bind(queue()).to(exchange()).with("dead");}/*** 定义处理延迟消息的交换机、队列和绑定*/@Beanpublic DirectExchange exchange1() {return new DirectExchange("delay.direct");}@Beanpublic Queue queue1() {return new Queue("delay.queue");}@Beanpublic Binding binding1() {return BindingBuilder.bind(queue1()).to(exchange1()).with("dead");}
}

定义延迟消息监听器:

    @RabbitListener(queues = "delay.queue")public void listen(String msg){log.info(LocalDateTime.now()+": "+msg);}

测试:

@Testvoid sendDeadMsg() {rabbitTemplate.convertAndSend("dead.direct", "dead", "我是死信", new MessagePostProcessor() {@Overridepublic Message postProcessMessage(Message message) throws AmqpException {
//                设置过期消息时间message.getMessageProperties().setExpiration("10000");return message;}});}

结果:
在这里插入图片描述
在这里插入图片描述
消费者在十秒钟后成功消费延迟消息

延迟消息插件

我们在之前通过死信交换机来实现延迟队列,但是死信交换机是专门用来存放无法处理的消息,并且使用死信交换机实现过于复杂,我们需要手动定义两个交换机和队列,因而RabbitMQ提供了延迟消息插件来让我们更简单的实现延迟消息。
原理:给消息设置延迟时间,当将消息放入MQ时,MQ的交换机不会立即将消息放入队列,而是会在交换机中暂存延迟时间过后将消息路由到队列中,可以让队列处理延迟消息。
安装插件:插件安装可以借鉴这篇博客
代码实现
消费者:

    @RabbitListener(bindings = @QueueBinding(value = @Queue(value = "delay.queue",durable = "true"),// 开启延迟交换机exchange = @Exchange(name = "delay.direct",delayed = "true"),key = "dead"))public void listen(String msg){log.info(msg);}
  @Testvoid sendDeadMsg() {rabbitTemplate.convertAndSend("delay.direct", "delay", "我是死信", new MessagePostProcessor() {@Overridepublic Message postProcessMessage(Message message) throws AmqpException {
//                设置延迟消息时间message.getMessageProperties().setDelay(10000);return message;}});}
http://www.dinnco.com/news/8864.html

相关文章:

  • 刚做的婚恋网站怎么推广营销组合策略
  • 沧浪企业建设网站电话站长工具在线查询
  • 政府机关单位网站建设方案南宁seo推广外包
  • 做网站还挣钱吗seo优化教程培训
  • 有什么网站做可以国外的生意免费制作网页平台
  • wordpress修改秒速广东seo价格是多少钱
  • 石家庄营销型网站建设公司网络营销策略ppt
  • 合肥红酒网站建设seo博客
  • 北京高端网站建设服务网站广告投放收费标准
  • 网站制作aqqseo引擎优化外包公司
  • win2003怎么做网站沈阳百度seo关键词排名优化软件
  • 网站域名更改百度推广账号怎么注册
  • 中小网站建设南宁关键词优化软件
  • 福建交通建设网站网络推广哪家做得比较好
  • 欧美电商网站seo应用领域有哪些
  • 电脑上做网站的软件网络营销主要干什么
  • 网站开发类标书报价明细表云南疫情最新数据消息中高风险地区
  • 温州做网站哪家公司好谷歌paypal官网
  • 用户访问域名劫持网站网站设计的毕业论文
  • 做web网站前端网站关键词排名优化推广软件
  • php网站建设步骤郑州网站开发顾问
  • winscp怎么做网站百度应用中心
  • 咖啡店网站模板广州seo代理计费
  • 在百度做网站seo关键词优化方法
  • 招一个程序员可以做网站吗游戏推广渠道有哪些
  • 外贸网站开发开发完整企业网站模板
  • 网站专栏怎么做漂亮宁波seo教学
  • 生产企业做网站有用吗百度seo关键词报价
  • 网站开发的调研合肥网站优化seo
  • wordpress做外贸网站市场调研怎么写