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

网站建设有关图片手机购物平台

网站建设有关图片,手机购物平台,软件开发的一般方法步骤,软件开发文档国标1.死信交换机(Dead Letter Exchange DLX) 1.1什么是死信交换机 ? 死信: 在RabbitMQ中,无法被消费者正常处理的消息称为死信(Dead Letter)。死信交换机: 用于接收死信的交换机。当消息成为死信时,RabbitMQ会将其重新路…

1.死信交换机(Dead Letter Exchange DLX)

1.1什么是死信交换机 ?

  • 死信: 在RabbitMQ中,无法被消费者正常处理的消息称为死信(Dead Letter)。
  • 死信交换机: 用于接收死信的交换机。当消息成为死信时,RabbitMQ会将其重新路由到死信交换机,再由死信交换机根据绑定规则路由到死信队列。

1.2消息成为死信的条件

  • 1.消息被拒绝:消费者调用basic.reject或basic.nack 并设置了requeue=false。
  • 2.消息过期:消息在队列中的存活时间(TTL)到期
  • 3.队列达到最大长度:队列已满,无法再接收新消息。

1.3死信交换机的配置

  • 在声明队列时,通过参数指定死信交换机和路由键
Map<String, Object> args = new HashMap<>();
args.put("x-dead-letter-exchange", "dlx.exchange"); // 死信交换机
args.put("x-dead-letter-routing-key", "dlx.routingKey"); // 死信路由键
channel.queueDeclare("normal.queue", true, false, false, args);

1.4死信交换机的应用场景

  • 异常消息处理:将处理失败的消息转移到死信交换机,便于后续分析或人工处理。
  • 延迟队列:通过死信交换机+TTL实现延迟队列功能。

2.延迟队列

2.1什么是延迟队列?

  • 延迟队列:消息在发送到队列后,不会立即被消费,而是延迟一段时间后被消费者处理。
  • 实现方式:RabbitMQ本身不支持直接的延迟队列功能,但可以通过死信交换机+TTL实现。

2.2延迟队列的实现

1.设置消息TTL:

  • 发送消息时设置消息的TTL(Time-To-Live)。
AMQP.BasicProperties properties = new AMQP.BasicProperties.Builder().expiration("10000") // TTL 为 10 秒.build();
channel.basicPublish("normal.exchange", "normal.routingKey", properties, body);

2.配置死信交换机:

  • 将消息发送到一个普通队列,并设置死信交换机和路由键。
Map<String, Object> args = new HashMap<>();
args.put("x-dead-letter-exchange", "dlx.exchange");
args.put("x-dead-letter-routing-key", "dlx.routingKey");
channel.queueDeclare("normal.queue", true, false, false, args);

3.创建死信队列:

  • 创建一个死信队列,绑定到死信交换机。
channel.queueDeclare("dlx.queue", true, false, false, null);
channel.queueBind("dlx.queue", "dlx.exchange", "dlx.routingKey");

4.消费者处理延迟消息:

  • 消费者从死信队列中获取延迟消息并进行处理。
channel.basicConsume("dlx.queue", true, (consumerTag, delivery) -> {// 处理延迟消息
}, consumerTag -> {});

2.3延迟队列的应用场景

  • 超时订单取消:用户下单后,如果30min内未支付,则自动取消订单。
  • 定时任务:在指定时间后执行任务,如发送提醒邮件。
  • 重试机制:消息处理失败后,延迟一段时间再重试。

3.示例:

3.1实现订单超时取消

1.发送订单消息:

AMQP.BasicProperties properties = new AMQP.BasicProperties.Builder().expiration("1800000") // TTL 为 30 分钟.build();
channel.basicPublish("order.exchange", "order.routingKey", properties, body);

2.配置死信交换机:

Map<String, Object> args = new HashMap<>();
args.put("x-dead-letter-exchange", "dlx.exchange");
args.put("x-dead-letter-routing-key", "dlx.routingKey");
channel.queueDeclare("order.queue", true, false, false, args);

3.创建死信队列:

channel.queueDeclare("dlx.queue", true, false, false, null);
channel.queueBind("dlx.queue", "dlx.exchange", "dlx.routingKey");

4.消费者处理超时订单:

channel.basicConsume("dlx.queue", true, (consumerTag, delivery) -> {// 处理超时订单String orderId = new String(delivery.getBody(), StandardCharsets.UTF_8);cancelOrder(orderId); // 取消订单
}, consumerTag -> {});

4.总结

  • 死信交换机:用于处理无法被正常消费的消息,常用于异常消息的处理和延迟队列
  • 延迟队列:通过死信交换机+TTL实现,适用于订单超时取消、定时任务、重试机制等场景。
  • 应用场景
    • 死信交换机异常消息处理、延迟队列
    • 延迟队列订单超时取消、定时任务、重试机制
http://www.dtcms.com/a/510926.html

相关文章:

  • 建筑设计方案网站企业设计公司
  • 成都网站建设优点网站开发流程分为哪几个阶段
  • 网站开发地图wordpress主题 ipcme
  • 中文域名网站建设网销怎么找客户
  • 相城区住房建设局网站wordpress 移动端网页
  • 我有虚拟服务器怎么快速做网站阿里巴巴网站建设教程视频
  • 信誉比较好的网上做任务的网站建设通小程序
  • pw域名网站商标注册查询网官网
  • 大兴建设网站设计一个商务网站
  • 比如做百度知道 .html,这些都是我们不可控制的网站!html网站设计实例代码
  • 云虚拟主机和网站建设襄州区住房和城乡建设局网站
  • 网站开发一个多少钱啊荣盛科技网站建设
  • 网站动态与静态山东省建设局网站
  • 深圳平湖网站开发网页游戏网站排名前10名
  • 淘宝二官方网站是做啥的台前网站建设公司
  • php综合网站源码张斌网站建设
  • 蓝色网站素材wordpress首页聚合模块
  • 导购类网站模板做零食网站的首页模板
  • 怀集县住房和城乡规划建设网站肇庆seo外包
  • 辽宁品牌建设促进会 网站潍坊高端网站设计
  • 网站免费申请优化设计七年级下册语文答案
  • 网站备案回访电话号码网站建设mdf
  • 网站登录页做多大尺寸的网站系统升级
  • 江西建网站镇江润州区建设局网站
  • 国际知名的论文网站重庆公司注销流程
  • 专做网页的网站可以做拟合的在线网站
  • 广东网站开发项目网页设计的基本原则
  • 北京做网站制作的公司什么视图适用于发送电子邮件和创建网页
  • 成都网站建设 3e房地产新闻最新消息今天
  • 织梦网站源码转换成wordpress厦门35网站建设公司