【手册】——mq延迟队列

目录

  • 一、背景介绍
  • 二、思路&方案
  • 三、过程
    • 1.项目为啥用延迟队列?
    • 2.项目为啥用三方延迟队列?
    • 3.项目中为啥用rabbitmq延迟队列?
    • 4.rabbitmq延迟队列的安装
    • 5.rabbitmq的延迟队列配置方式
      • 5.1.exchange配置
      • 5.2.queues配置
      • 5.3.exchange和queues的绑定
    • 6.rabbitmq的延迟队列java集成方式
      • 6.1.pom文件中加入依赖
      • 6.2.配置文件中加入配置项
      • 6.3.增加类,设置对应exchange和queues的消息监听
  • 四、总结
  • 五、升华

一、背景介绍

对于mq延时队列,产品中对应的应用场景用到了,自己也在执行过程中踩了认知上的坑,历历在目的画面让我不由得动笔总结。

二、思路&方案

  • 1.项目为啥用延迟队列?
  • 2.项目为啥用三方延迟队列?
  • 3.项目中为啥用rabbitmq延迟队列?
  • 4.rabbitmq延迟队列的安装
  • 5.rabbitmq的延迟队列配置方式
  • 6.rabbitmq的延迟队列java集成方式

三、过程

1.项目为啥用延迟队列?

项目中有这样一个业务需求,需要再未来某个时间点执行任务,这些任务或消息可能由于某些原因(如依赖其他任务的完成、等待特定时间、进行定时操作等)不能立即处理。通过使用延迟队列,可以确保这些任务或消息在指定的延迟时间后得到处理,从而实现更为灵活和高效的任务调度。

1.1. 解耦:通过将需要延迟处理的任务放入队列,实现了业务逻辑与延迟处理逻辑的解耦,使得代码更加清晰和易于维护。
可扩展性:延迟队列可以轻松地水平扩展,以应对大量延迟任务的处理需求。通过增加队列的数量或调整消费者的数量,可以灵活地调整系统的处理能力。
1.2. 高可用性:一些延迟队列实现(如RabbitMQ的延迟插件、Redis的有序集合等)提供了持久化机制,即使系统崩溃或重启,也能确保延迟任务不会丢失。

2.项目为啥用三方延迟队列?

2.1. 功能完善与性能优化:第三方延迟队列经过大量的实践和优化,通常具有更完善的功能和更高的性能。它们可能已经解决了许多常见的延迟队列问题,如精确的延迟时间控制、高并发处理、消息的持久化等,从而减少了自行开发可能遇到的困难和风险。
2.2. 可靠性与稳定性:第三方延迟队列通常经过严格的测试和验证,具有更高的可靠性和稳定性。它们可能提供了数据备份、容错处理、负载均衡等机制,确保在复杂的网络环境和系统压力下,延迟队列仍然能够稳定、可靠地运行。
2.3. 易于集成与维护:使用第三方延迟队列可以简化项目的集成工作。这些队列通常提供了丰富的API和文档,方便开发者快速集成到项目中。同时,由于第三方队列的维护和更新由专业的团队负责,开发者可以专注于业务逻辑的实现,而无需过多关注底层技术的细节。
2.4. 成本考虑:虽然自行编写延迟队列可以根据项目需求进行定制,但这通常需要投入大量的人力和时间成本。而使用成熟的第三方延迟队列,则可以快速实现功能,减少开发周期和成本。

3.项目中为啥用rabbitmq延迟队列?

3.1.RabbitMQ:通过插件或死信队列机制实现,具有灵活性和可扩展性,但需要一定的配置和管理工作。
3.2.Redis:利用有序集合数据结构实现,简单直观且性能较高,但需要定期轮询检查延迟消息。
3.3.Kafka:通常需要结合其他组件或自定义实现来模拟延迟队列,可以实现复杂的流处理和延迟逻辑,但相对复杂且需要更多的开发工作。
3.4.Amazon SQS:直接支持延迟队列功能,无需额外配置和管理工作,适合在云环境中使用。

4.rabbitmq延迟队列的安装

安装方式借鉴如下博文即可:
【rabbitmq 实现延迟消息-插件版本安装(docker环境)】

5.rabbitmq的延迟队列配置方式

5.1.exchange配置

在这里插入图片描述

5.2.queues配置

在这里插入图片描述

5.3.exchange和queues的绑定

在这里插入图片描述

6.rabbitmq的延迟队列java集成方式

6.1.pom文件中加入依赖

  <!-- amqp依赖,包含RabbitMQ-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
            <version>2.3.5.RELEASE</version>
        </dependency>

6.2.配置文件中加入配置项

spring:
  rabbitmq:
    host: rabbitmq域名
    port: rabbitmq端口
    virtual-host: 指定的virtual-host,默认可以是/
    username: 账号
    password: 密码
    #MQ业务配置
    #exchange
    classEndExchange: class_end_exchange
    #queues
    classEndQueues: Class.End.Queue
	#exchange和queues绑定时候的routingkey
    classEndRoutingKey: delayed_class_end
    

6.3.增加类,设置对应exchange和queues的消息监听

@Service
public class classEndQueues {
  
    @RabbitListener(queues = {"${spring.rabbitmq.classEndQueues}"})
    public synchronized void endClass(Message message){
        String messageString = new String(message.getBody());
        System.out.println(" endClass接收到的结束消息为:"+messageString );
      //要处理的业务
    }
}

四、总结

  • 1.逻辑性思考,一环一环,一步一步的去找,少了哪一步也都会出现断层,而断层所带来的代价是付出更多的时间成本;而总结的意义恰恰是避免类似的事情以后再付出更大的成本
  • 2.经验办事,想当然的办事所带来的认知陷阱,会成为一个扣了盖子的井
  • 3.于此形成相关手册,进行总结的过程是给自己未来建立一个连接点的过程

五、升华

写博文的深意,又有了更多维度的思考,它能够让作者静心思考,从宏观、微观、行为、心理的角度去思考、去总结、去升华。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/506838.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

文件操作(1)【文件打开和关闭】【文件的顺序读写(各种函数)】【sprintf和sscanf的理解】

一.什么是文件&#xff1f; 在程序设计中我们一般谈的文件有两种&#xff1a;程序文件和数据文件 1.程序文件 程序文件是包含计算机程序代码的文件。它通常包含一系列指令和算法&#xff0c;用于执行特定的任务或实现特定的功能。程序文件可以由不同的编程语言编写&#xff…

【C语言环境】Sublime中运行C语言时MinGW环境的安装

要知道&#xff0c;GCC 官网提供的 GCC 编译器是无法直接安装到 Windows 平台上的&#xff0c;如果我们想在 Windows 平台使用 GCC 编译器&#xff0c;可以安装 GCC 的移植版本。 目前适用于 Windows 平台、受欢迎的 GCC 移植版主要有 2 种&#xff0c;分别为 MinGW 和 Cygwin…

【Python】——变量名的命名规则

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…

Linux shell编程学习笔记42:md5sum

0 前言 前几天在国产电脑上遇到一个问题&#xff0c;先后接到两个文件&#xff0c;如何判断这两个文件内容是否相同&#xff1f; 如果是在Windows系统&#xff0c;可以用fc命令&#xff0c;或者用我自己写的FileInfo&#xff0c;提取两个文件有MD5、SHA1、CRC32值进行比较来判…

GANs和Diffusion模型(3)

接GANs和Diffusion模型&#xff08;2&#xff09; 扩散(Diffusion)模型 生成学习三重困难(Trilemma) 指生成学习(genrative learning)的模型都需要满足三个需求&#xff1a; 高质量的采样(High Quality Samples)&#xff1a;模型应该能生成非常高质量的采样快速采样(Fast S…

使用 Python 模拟布朗运动(和股票价格)

一、说明 本文先介绍布朗运动的概念&#xff0c;紧接着应用布朗方程到股票的随机斩落模型。进而用python实现&#xff0c;并给出各种各样的条件模型。从中烘托出股票模型的规律所在。 二、什么是布朗运动&#xff1f; 布朗运动以罗伯特布朗的名字命名&#xff0c;他是第一个在通…

持续交付与持续部署相关概念(CD)

目录 一、概述 二、持续交付基本概念 2.1 持续交付的含义 2.1.1 项目管理的视角 2.1.2 产品研发的视角 2.1.3 总结 2.2 持续交付涉及的运作环境 2.2.1 开发环境 2.2.2 测试环境 2.2.3 UAT环境 2.2.4 准生产环境 2.2.5 生产环境 2.3 总结 三、持续部署基本概念 3.…

创新之路:云边对接与行业生态的前沿探索

全球 80% 的数据来自物联网&#xff0c;不论是传统行业还是新兴行业&#xff0c;都将利用更多有价值的数据来驱动业务&#xff0c;实现降本增效。智慧教育、资产追踪、环境监测、工业物联网、智慧城市、家居互联、智慧电力、智慧农业。从智能电表到智能家居&#xff0c;从机器人…

RAG:检索增强生成系统如何工作

随着大型语言模型&#xff08;LLM&#xff09;的发展&#xff0c;人工智能世界取得了巨大的飞跃。经过大量数据的训练&#xff0c;LLM可以发现语言模式和关系&#xff0c;使人工智能工具能够生成更准确、与上下文相关的响应。 但LLM也给人工智能工程师带来了新的挑战&#xff…

shopee、lazada、temu测评自养号策略解析

在跨境电商领域&#xff0c;测评作为提升销量的重要手段&#xff0c;其策略的制定和实施显得尤为重要。特别是对于Shopee和Lazada两大主流平台上的卖家而言&#xff0c;如何有效利用测评策略提升产品销量成为了一大挑战。 自养号测评系统可以批量注册买家账号、模拟真实人工操…

U8二次开发-钉钉集成

钉钉开放平台作为企业沟通和协作的重要工具,其技术的每一次迭代都为企业带来了新的机遇和挑战。随着企业对于高效沟通和智能化管理的需求日益增长,钉钉平台的SDK更新显得尤为重要。把传统的U8与钉钉平台集成,可以有效的将业务功能和角色进行前移,打破应用系统二八原则,即8…

Vue(十二):脚手架配置代理,github案例,插槽

一、脚手架配置代理 老师讲的主要有两种方法&#xff1a; 但是我的没有proxy&#xff0c;只有proxyTable,之前一直不成功&#xff0c;现在我是这样配置的&#xff1a; config文件夹下的index.js: App.vue: 然后就成功了&#xff1a;&#xff08;我真服了&#xff0c;之前在这…

Linux中xz一次恶意后门处理的名场面-尚文网络xUP楠哥

进Q群11372462领取专属报名福利! 说在前面 Linux系统中所使用的xz软件是用于日常文件的归档压缩工具&#xff0c;据悉就在今日&#xff0c;Utils 5.6.0、5.6.1版本存在恶意后门植入漏洞&#xff08;CVE-2024-3094&#xff09;。开发人员在调查SSH性能问题时发现了涉及XZ Util…

Taro多行文本最多展示5行,超出“查看更多”展示,点击弹层

Taro中&#xff0c;页面需求&#xff1a; 多行文本&#xff0c;展示最多展示5行&#xff0c;超出5行&#xff0c;展示“查看更多”按钮&#xff0c;点击弹层展示文本详细信息。 弹层代码就不说了&#xff0c;着重说一下怎么获取区域高度&#xff5e; 1.区域设置max-height&am…

2_2.Linux中的远程登录服务

# 一.Openssh的功能 # 1.sshd服务的用途# #作用&#xff1a;可以实现通过网络在远程主机中开启安全shell的操作 Secure SHell >ssh ##客户端 Secure SHell daemon >sshd ##服务端 2.安装包# openssh-server 3.主配置文件# /etc/ssh/sshd_conf 4.…

嵌入式|蓝桥杯STM32G431(HAL库开发)——CT117E学习笔记12:DAC数模转换

系列文章目录 嵌入式|蓝桥杯STM32G431&#xff08;HAL库开发&#xff09;——CT117E学习笔记01&#xff1a;赛事介绍与硬件平台 嵌入式|蓝桥杯STM32G431&#xff08;HAL库开发&#xff09;——CT117E学习笔记02&#xff1a;开发环境安装 嵌入式|蓝桥杯STM32G431&#xff08;…

Php_Code_challenge12

题目&#xff1a; 答案&#xff1a; 解析&#xff1a; 字符串拼接。

iPhone设备中调试应用程序崩溃日志的高效方法探究

​ 目录 如何在iPhone设备中查看崩溃日志 摘要 引言 导致iPhone设备崩溃的主要原因是什么&#xff1f; 使用克魔助手查看iPhone设备中的崩溃日志 奔溃日志分析 总结 摘要 本文介绍了如何在iPhone设备中查看崩溃日志&#xff0c;以便调查崩溃的原因。我们将展示三种不同的…

Windows 上路由、端口转发配置,跨网络地址段

一、背景 有时候我们会遇到这样的场景&#xff0c;一批同一局域网中只有某一台主机带外且系统为windows&#xff0c;局域网中其他非带外的主机要想访问外网&#xff0c;本文将介绍如何配置在带外主机上开启路由及端口转发。 二、配置操作 2.1、带外主机开启路由转发 1&#x…

Centos7.X服务器搭建VOS系统的REC录音转换MP3,并支持外呼系统wav转换MP3

由于有的公司客户需要自己下载录音或做话务质检等工作需要&#xff0c;需要从VOS系统中把录音下载到其它服务器使用&#xff0c;但是VOS录音格式是REC格式的&#xff0c;就算下载下来了也无法直接播放&#xff0c;因此我们需要搭建一台转换MP3的服务器来完成需求&#xff01; 外…