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

网站注册了域名然后怎么做营销策划方案包括哪些内容

网站注册了域名然后怎么做,营销策划方案包括哪些内容,兰州模板网站建设,宁夏建设工程招标投标信息管理中心网站文章目录 什么是死信交换机?死信交换机实现延迟消息的思路实现过程配置类消费者监听死信队列发送延迟消息 注意事项总结 在开发过程中,我们常常会遇到需要延迟处理某些消息的场景,例如订单的支付超时处理、短信的定时发送等。本文将介绍如何使…

文章目录

    • 什么是死信交换机?
    • 死信交换机实现延迟消息的思路
    • 实现过程
      • 配置类
      • 消费者监听死信队列
      • 发送延迟消息
    • 注意事项
    • 总结

在开发过程中,我们常常会遇到需要延迟处理某些消息的场景,例如订单的支付超时处理、短信的定时发送等。本文将介绍如何使用RabbitMQ的死信交换机(Dead Letter Exchange,DLX)来实现延迟消息的处理。

什么是死信交换机?

死信交换机是一种特殊的交换机,用于处理不能被正常消费的消息。当消息在队列中出现以下几种情况时,会被转发到死信交换机:

  1. 消息被拒绝(Basic.Reject或Basic.Nack)并且requeue参数设置为false。
  2. 消息在队列中的存活时间超过了TTL(Time To Live)。
  3. 队列的最大长度已满,导致消息被丢弃。

通过配置死信交换机,我们可以将这些“死信”转发到一个特殊的队列,从而进行后续处理。

死信交换机实现延迟消息的思路

利用消息的TTL属性和死信交换机,我们可以实现延迟消息的处理。具体步骤如下:

  1. 创建一个普通交换机和队列,队列绑定一个死信交换机。
  2. 发送消息到普通队列,并设置消息的TTL。
  3. 消息过期后,会转发到死信交换机,死信交换机再将消息路由到实际处理的队列中。

实现过程

配置类

首先,我们需要配置普通交换机、队列和绑定关系:

package com.itheima.consumer.config;import org.springframework.amqp.core.*;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class NormalConfiguration {@Beanpublic DirectExchange normalExchange() {return ExchangeBuilder.directExchange("normal.direct").build();}@Beanpublic Queue normalQueue() {return QueueBuilder.durable("normal.queue").deadLetterExchange("dlx.direct").build();}@Beanpublic Binding normalExchangeBinding(Queue normalQueue, DirectExchange normalExchange) {return BindingBuilder.bind(normalQueue).to(normalExchange).with("hi");}
}

在上述配置中,我们创建了一个普通交换机normal.direct,以及一个普通队列normal.queue,并将队列绑定到了死信交换机dlx.direct

消费者监听死信队列

接下来,我们需要定义一个消费者来监听死信队列,并处理延迟后的消息:

import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.core.ExchangeTypes;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;@Component
public class DlxMessageListener {private static final Logger log = LoggerFactory.getLogger(DlxMessageListener.class);@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "dlx.queue", durable = "true"),exchange = @Exchange(name = "dlx.direct", type = ExchangeTypes.DIRECT),key = {"hi"}))public void listenDlxQueue1(String message) {log.info("消费者监听到dlx.queue消息:{}", message);}
}

发送延迟消息

最后,我们编写一个测试方法来发送延迟消息:

import org.junit.jupiter.api.Test;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;@SpringBootTest
public class DelayMessageTest {@Autowiredprivate RabbitTemplate rabbitTemplate;@Testvoid testSendDelayMessage() {rabbitTemplate.convertAndSend("normal.direct", "hi", "hello", message -> {message.getMessageProperties().setExpiration("10000");return message;});}
}

在上述测试方法中,我们向普通队列发送了一条消息,并设置其TTL为10000毫秒(即10秒)。当消息在普通队列中存活超过10秒后,会被转发到死信交换机,然后由消费者监听并处理。

注意事项

需要注意的是,RabbitMQ的消息过期是基于追溯方式来实现的,也就是说当一个消息的TTL到期以后,不一定会立即被移除或投递到死信交换机,而是在消息恰好处于队首时才会被处理。当队列中消息堆积很多的时候,过期消息可能不会被按时处理,因此你设置的TTL时间不一定准确。

总结

通过以上配置和代码,我们实现了使用RabbitMQ死信交换机来处理延迟消息。利用死信交换机的机制,我们可以方便地实现各种复杂的消息处理场景,提高系统的灵活性和可靠性。

http://www.wangmingla.cn/news/83282.html

相关文章:

  • 做pc端大型网站 前端用网盟推广
  • 做网站项目团队口号深圳网站建设推广方案
  • 网站 空间 是什么成都网站制作设计公司
  • 公司注册查询核名广州百度seo优化排名
  • 做产品推广什么网站会比较好qq引流推广平台
  • 呼市企业网站制作sem论坛
  • webgl网站开发南宁推广公司
  • 如何建单页网站栏目互联网营销具体做什么
  • 教做粘土的网站上海平台推广的公司
  • 免费建站推广搜索推广代运营
  • 莆田做外贸网站宁波seo咨询
  • 河南省建设行业证书查询网站网络设计
  • 专业企业网站开发百度一下首页百度一下知道
  • 石家庄网页设计公司搜狗关键词优化软件
  • 网站地图怎么做XML可以直接进入的舆情网站
  • 党建网站建设可行性分析自动友链网
  • 代帮企业做网站新闻头条最新消息今日头条
  • 个性化网站建设附近学电脑培训班
  • 成都疫情最新消息发布seo工作职责
  • 渝北集团网站建设培训学校管理系统
  • 做网站什么语言最好电商seo与sem是什么
  • 陕西交通建设集团西商分公司网站汕头网站推广
  • 合伙企业怎么注册公司四川seo推广方案
  • phpmysql网站开发视频企业培训公司
  • 北京手机网站制作多少钱百度广告推广
  • 应聘网站开发题目sem 优化价格
  • 自学网站开发条件网络营销推广方案
  • 加强网站基础建设项目百度账号中心官网
  • 我想做自己网站怎么做今天有哪些新闻
  • 东城网站建设seo百度关键词优化软件