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

【RabbitMQ】延迟队列

1.概述

延迟队列其实就是队列里的消息是希望在指定时间到了以后或之前取出和处理,简单来说,延时队列就是用来存放需要在指定时间被处理的元素的队列。

延时队列的使用场景:

1.订单在十分钟之内未支付则自动取消

2.新创建的店铺,如果在十天内都没有上传过商品,则自动发送消息提醒。

3.用户注册成功后,如果三天内没有登陆则进行短信提醒。

4.用户发起退款,如果三天内没有得到处理则通知相关运营人员。

5.预定会议后,需要在预定的时间点前十分钟通知各个与会人员参加会议

2.代码演示 

代码是用springboot整合的。

先导入依赖

<dependencies><!--RabbitMQ 依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.47</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency><!--RabbitMQ 测试依赖--><dependency><groupId>org.springframework.amqp</groupId><artifactId>spring-rabbit-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope><exclusions><exclusion><groupId>org.junit.vintage</groupId><artifactId>junit-vintage-engine</artifactId></exclusion></exclusions></dependency>
</dependencies>

配置文件

spring.rabbitmq.host=192.168.10.137
spring.rabbitmq.port=5672
spring.rabbitmq.username=rabbit
spring.rabbitmq.password=rabbit
spring.rabbitmq.virtual-host=/

启动器

@SpringBootApplicationpublic class App {public static void main(String[] args) {SpringApplication.run(App.class,args);}}

 需求如下:创建两个队列 QA 和 QB,两者队列 TTL 分别设置为 10S 和 40S,然后在创建一个交 换机 X 和死信交 换机 Y,它们的类型都是 direct,创建一个死信队列 QD,它们的绑定关系如下:

定义配置类,描述上图的队列,交换机以及队列和交换机之间的关系

import org.springframework.amqp.core.*;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import java.util.HashMap;
import java.util.Map;// 使用@Configuration注解表明这是一个配置类,Spring容器会扫描该类来获取Bean的定义信息
@Configuration
public class DelayedQueueConfig {// 定义直连类型(Direct)的交换机,名称为xExchange// @Bean注解用于将方法返回的对象注册为Spring容器中的一个Bean,"xExchange"是该Bean的名称@Bean("xExchange")public DirectExchange xExchange() {// 创建并返回一个名为"X"的DirectExchange实例,DirectExchange类型的交换机根据路由键直接转发消息return new DirectExchange("X");}// 声明另一个直连类型的交换机,名称为yExchange@Bean("yExchange")public DirectExchange yExchange() {// 创建并返回一个名为"Y"的DirectExchange实例return new DirectExchange("Y");}// 声明队列queueA@Bean("queueA")public Queue queueA() {// 创建一个HashMap用于存储队列的属性参数Map<String, Object> args = new HashMap<>();// 设置死信交换机(当消息在队列中过期或被否定确认等情况时,消息会被转发到这个交换机)为yExchangeargs.put("x-dead-letter-exchange", "Y");// 设置死信路由键,当消息进入死信交换机后,根据这个路由键来路由到对应的死信队列args.put("x-dead-letter-routing-key", "YD");// 设置消息在队列中的存活时间(即延时时间)为10000毫秒,也就是10秒,这使得queueA成为一个延时队列args.put("x-message-ttl", 10000);// 创建一个持久化的队列(QueueBuilder.durable方法),名称为"QA",并带上前面设置的属性参数return QueueBuilder.durable("QA").withArguments(args).build();}// 绑定交换机xExchange和队列queueA// @Qualifier注解用于根据指定的Bean名称来注入对应的Bean实例,这里分别指定了要注入的队列和交换机实例@Beanpublic Binding queueQABindingX(@Qualifier("queueA") Queue queueA,@Qualifier("xExchange") DirectExchange xExchange) {// 使用BindingBuilder将队列queueA绑定到交换机xExchange上,绑定的路由键为"XA"return BindingBuilder.bind(queueA).to(xExchange).with("XA");}// 声明队列queueB,设置其延时时间为40秒@Bean("queueB")public Queue queueB() {Map<String, Object> args = new HashMap<>();// 同样设置死信交换机为yExchangeargs.put("x-dead-letter-exchange", "Y");// 设置死信路由键为"YD"args.put("x-dead-letter-routing-key", "YD");// 设置消息在队列中的存活时间为40000毫秒,即40秒,使queueB成为延时队列args.put("x-message-ttl", 40000);// 创建一个持久化的队列,名称为"QB",并带上相关属性参数return QueueBuilder.durable("QB").withArguments(args).build();}// 绑定交换机xExchange和队列queueB@Beanpublic Binding queueQBBindingX(@Qualifier("queueB") Queue queueB,@Qualifier("xExchange") DirectExchange xExchange) {// 将队列queueB绑定到交换机xExchange上,绑定的路由键为"XB"return BindingBuilder.bind(queueB).to(xExchange).with("XB");}// 声明死信队列queueD@Bean("queueD")public Queue queueD() {// 创建一个名称为"QD"的队列,用于接收从延时队列中过期转移过来的消息return new Queue("QD");}// 声明死信交换机yExchange和死信队列queueD的绑定关系@Beanpublic Binding deadQueueBindingQD(@Qualifier("queueD") Queue queueD,@Qualifier("yExchange") DirectExchange yExchange) {// 使用BindingBuilder将死信队列queueD绑定到死信交换机yExchange上,绑定的路由键为"YD"return BindingBuilder.bind(queueD).to(yExchange).with("YD");}
}

 生产者

// @RestController注解表明该类是一个RESTful风格的控制器,用于处理HTTP请求并返回JSON等格式的数据
@RestController 
// @RequestMapping("ttl")注解用于映射请求路径,所有以"/ttl"开头的请求会被该控制器处理
@RequestMapping("ttl") 
public class SendMessageController { // @Resource注解用于自动装配RabbitTemplate实例,RabbitTemplate是Spring AMQP提供的用于操作RabbitMQ的工具类@Resource RabbitTemplate rabbitTemplate; // 该方法用于处理"/sendMsg/{message}"路径的请求,是消息发送的逻辑所在// @RequestMapping("sendMsg/{message}")注解将该方法映射到指定的请求路径,其中{message}是一个路径变量@RequestMapping("sendMsg/{message}") public void sendMessage(@PathVariable("message") String message){ // 使用rabbitTemplate的convertAndSend方法向RabbitMQ发送消息// 第一个参数"X"指定交换机名称,对应前面配置的xExchange// 第二个参数"XA"指定路由键,用于将消息路由到绑定了该路由键的队列(这里是queueA)// 消息内容是拼接后的字符串,表明消息来自ttl为10秒钟的延时队列,并带上传入的参数messagerabbitTemplate.convertAndSend("X", "XA", "消息来自ttl为10秒钟的延时队列" + message); // 同理,这条消息发送到交换机"X",通过路由键"XB"路由到queueB// 消息内容表明来自ttl为40秒钟的延时队列rabbitTemplate.convertAndSend("X", "XB", "消息来自ttl为40秒钟的延时队列" + message); }
}

消费者

// @Component注解将该类标记为一个Spring组件,使其能被Spring容器扫描并管理
@Component 
// @Slf4j注解是Lombok提供的,用于自动生成日志对象log,方便在类中记录日志
@Slf4j 
public class MessageConsumerListener { // @RabbitListener(queues = "QD")注解表明该方法是一个RabbitMQ消息监听器,监听名为"QD"的队列// 当队列"QD"(即前面配置的死信队列)中有消息时,该方法会被触发执行@RabbitListener(queues = "QD") public void getMessage(Message message, Channel channel) throws Exception{ // 获取消息体内容,将消息的字节数组转换为字符串String msg = new String(message.getBody()); // 使用日志对象log记录信息,输出当前时间以及从死信队列收到的消息内容log.info("当前时间是:{},收到死信队列的消息{}",new Date().toString(),msg); }
}

我们上面构建的延时队列太局限性了,因为我们直接写死了延时队列的时间,但我们实际的应用中很多情况都是根据客户端动态设置时间,比如腾讯会议我们要预定多久的会。

所以下面这个案例新增了一个队列QC,他不设置TTL,而是根据传送的数据来动态设定。

我们在配置类中加上QC和交换机x交换机y之间的绑定关系

@Configuration
public class DelayedQueueConfig {@Bean("queueC")public Queue queueC() {Map<String, Object> args = new HashMap<>();//设置绑定死信交换机的属性args.put("x-dead-letter-exchange", "Y");args.put("x-dead-letter-routing-key", "YD");return QueueBuilder.durable("QC").withArguments(args).build();}//绑定队列QC和交换机X之间的关系@Beanpublic Binding queueCBindingX(@Qualifier("queueC") Queue queueC,@Qualifier("xExchange") DirectExchange xExchange) {return BindingBuilder.bind(queueC).to(xExchange).with("XC");}
}

 定义生产者

// @RestController注解表明该类是一个RESTful风格的控制器,用于处理HTTP请求并返回JSON等格式的数据
@RestController 
// @RequestMapping("ttl")注解用于映射请求路径,所有以"/ttl"开头的请求会被该控制器处理
@RequestMapping("ttl") 
public class SendMessageController { // @Resource注解用于自动装配RabbitTemplate实例,RabbitTemplate是Spring AMQP提供的用于操作RabbitMQ的工具类@Resource RabbitTemplate rabbitTemplate; // 该方法用于处理"/sendttlMessage/{message}/{ttl}"路径的请求,是消息发送的逻辑所在// @RequestMapping("sendttlMessage/{message}/{ttl}")注解将该方法映射到指定的请求路径,其中{message}和{ttl}是路径变量@RequestMapping("sendttlMessage/{message}/{ttl}") public void sendTtlMessage(@PathVariable("message") String message, @PathVariable("ttl") String ttl) { // 使用rabbitTemplate的convertAndSend方法向RabbitMQ发送消息// 第一个参数"X"指定交换机名称// 第二个参数"XC"指定路由键,用于将消息路由到绑定了该路由键的队列// 第三个参数message是消息内容// 第四个参数是一个Lambda表达式,用于在发送消息前设置消息的过期时间(通过setExpiration方法)// 设置的过期时间由路径变量ttl传入,单位为毫秒rabbitTemplate.convertAndSend("X", "XC", message, msg -> { msg.getMessageProperties().setExpiration(ttl); return msg; }); }
}

相关文章:

【RabbitMQ】延迟队列

1.概述 延迟队列其实就是队列里的消息是希望在指定时间到了以后或之前取出和处理&#xff0c;简单来说&#xff0c;延时队列就是用来存放需要在指定时间被处理的元素的队列。 延时队列的使用场景&#xff1a; 1.订单在十分钟之内未支付则自动取消 2.新创建的店铺&#xff0c;…...

深兰科技携多款AI医疗创新成果亮相第七届世界大健康博览会

4月8日&#xff0c;以“AI赋能 健康生活”为主题的2025年(第七届)世界大健康博览会(以下简称健博会)在武汉隆重开幕。应参展企业武汉市三甲医院——武汉中心医院的邀请&#xff0c;深兰科技最新研发的新一代智慧医疗解决方案和产品在其展位上公开亮相。 本届展会吸引了来自18个…...

20周年系列|美创科技再度入围「年度高成长企业」系列榜单

近日&#xff0c;资深产业信息服务平台【第一新声】发布「2024年度科技行业最佳CEO及高成长企业榜」&#xff0c;美创科技凭借在数据安全领域的持续创新和广泛行业实践&#xff0c; 再度入围“年度网络安全高成长企业”、“年度高科技高成长未来独角兽企业TOP30”。 美创科技作…...

saltstack分布式部署

一、saltstack分布式 在minion数量过多时&#xff0c;通过部署salt代理&#xff0c;减轻master负载 1、在master上删除说有minion证书 2、在minion上删除旧master信息 3、安装部署salt-syndic 4、修改minion 5、在master上签署代理的证书 6、在代理上签署minion证书 7、测试...

CCRC 与 EMVCo 双认证:中国智能卡企业的全球化突围

在全球经济一体化的浪潮中&#xff0c;智能卡行业正经历着前所未有的变革与发展。中国智能卡企业凭借技术优势与成本竞争力&#xff0c;在国内市场成绩斐然。然而&#xff0c;要想在国际市场站稳脚跟&#xff0c;获取权威认证成为关键一步。CCRC 与 EMVCo 双认证&#xff0c;宛…...

逆向工程的多层次解析:从实现到领域的全面视角

目录 前言1. 什么是逆向工程&#xff1f;2. 实现级逆向&#xff1a;揭示代码背后的结构2.1 抽象语法树的构建2.2 符号表的恢复2.3 过程设计表示的推导 3. 结构级逆向&#xff1a;重建模块之间的协作关系3.1 调用图与依赖分析3.2 程序与数据结构的映射 4. 功能级逆向&#xff1a…...

【Docker项目实战】使用Docker部署ToDoList任务管理工具

【Docker项目实战】使用Docker部署ToDoList任务管理工具 一、ToDoList介绍1.1 ToDoList简介1.2 ToDoList主要特点二、本次实践规划2.1 本地环境规划2.2 本次实践介绍三、本地环境检查3.1 检查Docker服务状态3.2 检查Docker版本3.3 检查docker compose 版本四、下载ToDoList镜像…...

基于SpinrgBoot+Vue的医院管理系统-026

一、项目技术栈 Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SpringBoot 前端&#xff1a;Vue开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 二、功能介绍 (1)…...

如何进行数据安全风险评估总结

一、基于场景进行安全风险评估 一、概述 数据安全风险评估总结(一)描述了数据安全风险评估的相关理论,数据安全应该关注业务流程,以基础安全为基础,以数据生命周期及数据应用场景两个维度为入口进行数据安全风险评估。最后以《信息安全技术 信息安全风险评估规范》为参考,…...

用 npm list -g --depth=0 探索全局包的秘密 ✨

用 npm list -g --depth0 探索全局包的秘密 &#x1f680;✨ 嗨&#xff0c;各位开发者朋友们&#xff01;&#x1f44b; 今天我们要聊一个超实用的小命令——npm list -g --depth0&#xff01;它就像一个“全局包侦探”&#x1f575;️‍♂️&#xff0c;能帮你快速查出系统中…...

依靠视频设备轨迹回放平台EasyCVR构建视频监控,为幼教连锁园区安全护航

一、项目背景 幼教行业连锁化发展态势越发明显。在此趋势下&#xff0c;幼儿园管理者对于深入了解园内日常教学与生活情况的需求愈发紧迫&#xff0c;将这些数据作为提升管理水平、优化教育服务的重要依据。同时&#xff0c;安装监控系统不仅有效缓解家长对孩子在校安全与生活…...

新闻发稿软文发布投稿选择媒体时几大注意

企业在选择新闻稿发布媒体时&#xff0c;需要综合考虑以下几个关键因素&#xff1a; 1. 匹配媒体定位 企业应根据自身品牌定位和传播目标&#xff0c;选择与之契合的媒体平台。确保新闻稿的内容和风格与媒体的定位高度一致&#xff0c;从而提高稿件被采纳的可能性。 2. 衡量…...

[Scade One] Swan与Scade 6的区别 - signal 特性的移除

signal 特性移除 在 Scade One 引入的Swan中&#xff0c;移除了Scade 6中存在的signal 特性。比如 Scade 6 中的signal声明 sig sig_o;或者signal使用&#xff0c;比如 o sig_o; 在Swan中已经被移除。 不过Swan仍旧保留了对布尔流的emit操作&#xff0c;比如 emit a if c …...

亚马逊推出“站外代购革命“:跨境购物进入全平台整合时代

一、创新功能解析&#xff1a;平台边界消融的购物新范式 亚马逊最新推出的External Product Fulfillment&#xff08;EPF&#xff09;服务&#xff0c;正以技术创新重构全球电商格局。这项被称作"代购终结者"的功能具备三大核心突破&#xff1a; 全链路智能化 • 智能…...

Java 常用安全框架的 授权模型 对比分析,涵盖 RBAC、ABAC、ACL、基于权限/角色 等模型,结合框架实现方式、适用场景和优缺点进行详细说明

以下是 Java 常用安全框架的 授权模型 对比分析&#xff0c;涵盖 RBAC、ABAC、ACL、基于权限/角色 等模型&#xff0c;结合框架实现方式、适用场景和优缺点进行详细说明&#xff1a; 1. 授权模型类型与定义 模型名称定义特点RBAC&#xff08;基于角色的访问控制&#xff09;通…...

达梦数据库迁移问题总结

问题一、DTS工具运行乱码 开启图形化 [rootlocalhost ~]# xhost #如果命令不存在执行sudo yum install xorg-x11-server-utils xhost: unable to open display "" [rootlocalhost ~]# su - dmdba 上一次登录&#xff1a; 三 4月 9 19:50:44 CST 2025 pts/0 上…...

JS | 函数柯里化

函数柯里化&#xff08;Currying&#xff09;&#xff1a;将一个接收多个参数函数&#xff0c;转换为一系列只接受一个参数的函数的过程。即 逐个接收参数。 例子&#xff1a; 普通函数&#xff1a; function add(a, b, c) {return a b c; } add(1, 2, 3); // 输出 6柯里化…...

Elasticsearch中的基本全文搜索和过滤

Elasticsearch中的基本全文搜索和过滤 知识点参考: https://www.elastic.co/guide/en/elasticsearch/reference/current/full-text-filter-tutorial.html#full-text-filter-tutorial-range-query 1. 索引设计与映射 多字段类型&#xff08;Multi-Fields&#xff09; &#xff…...

蓝桥杯嵌入式第十五届

一、底层 根据它的硬件配置可以看出来这套题目使用到了按键、LED、LCD、输入捕获这几个功能 &#xff08;1&#xff09;输入捕获功能 首先在CubeMx里面的配置 题目中说到了我们使用的是PA15和PB4&#xff08;实际在板子上对应的的是R39和R40&#xff09;&#xff0c;所以我们…...

基于ueditor编辑器的功能开发之给编辑器图片增加水印功能

用户需求&#xff0c;双击编辑器中的图片的时候&#xff0c;出现弹框&#xff0c;用户可以选择水印缩放倍数、距离以及水印所放置的方位&#xff08;当然有很多水印插件&#xff0c;位置大小透明度用户都能够自定义&#xff0c;但是用户需求如此&#xff0c;就自己写了&#xf…...

DDR中的DLL

在DDR4内存系统中&#xff0c;DLL&#xff08;Delay Locked Loop&#xff0c;延迟锁相环&#xff09;是一个非常重要的组件&#xff0c;用于确保数据信号&#xff08;DQS&#xff09;和时钟信号&#xff08;CK&#xff09;之间的同步。以下是DLL的作用以及DLL on和DLL off的影响…...

Python学习之jieba

Python学习之jieba jieba是优秀的中文分词第三方库,由于中文文本之间每个汉字都是连续书写的,我们需要通过特定的手段来获得其中的每个词组,这种手段叫做分词,我们可以通过jieba库来完成这个过程。jieba库的分词原理:利用一个中文词库,确定汉字之间的关联频率,汉字向概率大的组…...

快速幂fast_pow

快速幂算法讲解 快速幂算法是一种高效计算幂运算的算法&#xff0c;其核心思想是利用指数的二进制分解&#xff0c;把幂运算的时间复杂度从 O(p) 降低到 O(logp)。 原理 假设要计算 an&#xff0c;将 n 表示成二进制形式&#xff1a;n2k1​2k2​⋯2km​&#xff0c;那么 ana…...

Go并发背后的双引擎:CSP通信模型与GMP调度|Go语言进阶(4)

为什么需要理解CSP与GMP&#xff1f; 当我们启动一个Go程序时&#xff0c;可能会创建成千上万个goroutine&#xff0c;它们是如何被调度到有限的CPU核心上的&#xff1f;为什么Go能够如此轻松地处理高并发场景&#xff1f;为什么有时候我们的并发程序会出现奇怪的性能瓶颈&…...

42、JavaEE高级主题:WebSocket详解

WebSocket 一、WebSocket协议与实现 WebSocket是一种基于TCP协议的全双工通信协议&#xff0c;能够在客户端和服务器之间建立实时、双向的通信通道。通过WebSocket&#xff0c;客户端和服务器可以在任何时候发送数据&#xff0c;并立即接收到对方的响应。 1.1 WebSocket协议…...

UGUI源代码之Text—实现自定义的字间距属性

以下内容是根据Unity 2020.1.01f版本进行编写的 UGUI源代码之Text—实现自定义的字间距属性 1、目的2、参考3、代码阅读4、准备修改UGUI源代码5、实现自定义Text组件&#xff0c;增加字间距属性6、最终效果 1、目的 很多时候&#xff0c;美术在设计的时候是想要使用文本的字间…...

【AI】MCP概念

一文讲透 MCP&#xff08;附 Apifox MCP Server 内测邀请&#xff09; 7分钟讲清楚MCP是什么&#xff1f;统一Function calling规范&#xff0c;工作量锐减至1/6&#xff0c;人人手搓Manus&#xff01;&#xff1f; | 一键链接千台服务器&#xff0c;几行代码接入海量外部工具…...

HarmonyOS:使用geoLocationManager (位置服务)获取位置信息

一、简介 位置服务提供GNSS定位、网络定位&#xff08;蜂窝基站、WLAN、蓝牙定位技术&#xff09;、地理编码、逆地理编码、国家码和地理围栏等基本功能。 使用位置服务时请打开设备“位置”开关。如果“位置”开关关闭并且代码未设置捕获异常&#xff0c;可能导致应用异常。 …...

深入解析原生鸿蒙中的 RN 日志系统:从入门到精通!

全文目录&#xff1a; 开篇语&#x1f4d6; 目录&#x1f3af; 前言&#xff1a;鸿蒙日志系统究竟有多重要&#xff1f;&#x1f6e0;️ 鸿蒙 RN 日志系统的基础结构&#x1f4dc; 1. 日志的作用⚙️ 2. 日志分类 &#x1f527; 如何在鸿蒙 RN 中使用日志系统&#x1f58b;️ 1…...

【前端】【Nuxt3】Nuxt3中usefetch,useAsyncData,$fetch使用与区别

一、Nuxt3 中不同数据获取方式的请求行为对比 &#xff08;一&#xff09;总结&#xff1a;请求行为一览 useFetch 和 useAsyncData 是 Nuxt 推荐的数据获取 API&#xff0c;自动集成 SSR 与客户端导航流程。$fetch 是更底层的请求方法&#xff0c;不具备自动触发、缓存等集成…...

【Linux系统】Linux基础指令

l i n u x linux linux 命令是对 L i n u x Linux Linux 系统进行管理的命令。对于 L i n u x Linux Linux 系统来说&#xff0c;无论是中央处理器、内存、磁盘驱动器、键盘、鼠标&#xff0c;还是用户等都是文件&#xff0c; L i n u x Linux Linux 系统管理的命令是它正常运…...

Android中Jetpack设计理念、核心组件 和 实际价值

一、Jetpack 的定义与定位&#xff08;基础必答&#xff09; Jetpack 是 Google 推出的 Android 开发组件集合&#xff0c;旨在&#xff1a; 加速开发&#xff1a;提供标准化、开箱即用的组件 消除样板代码&#xff1a;解决传统开发中的重复劳动问题 兼容性保障&#xff1a;…...

flutter开发音乐APP(前提准备)

1、项目的一些环境&#xff1a; 2、接口文档&#xff1a; 酷狗音乐 NodeJS 版 API 3、接口数据结构化 Instantly parse JSON in any language | quicktype UI样式借鉴参考&#xff1a; Coffee-Expert/Apple-Music-New-UI: Apple Music Clone on Flutter, with redesigned UI…...

网络协议学习

最近在适配ESP32的网络驱动&#xff0c;借此机会先学习一下网络通信协议。 以太网帧、IP包及TCP与UDP的报文格式 提问腾讯元宝提示词&#xff1a; TCP窗口是干什么的拥塞窗口是什么的...

示波器直流耦合与交流耦合:何时使用哪种?

直流耦合和交流耦合的基本区别应该在于它们如何处理信号的直流分量和交流分量。直流分量是指信号中的固定电压部分&#xff0c;而交流分量则是信号中变化的电压部分。 例如&#xff0c;一个5V的直流电压叠加了一个1V的正弦波交流信号&#xff0c;整个信号会在4V到6V之间波动。如…...

js解除禁止复制、禁止鼠标右键效果

有的网页会禁止复制&#xff0c;甚至禁止鼠标右键&#xff0c;如何解决 按F12进入检查模式&#xff0c;在控制台输入下面的js代码 1.解除禁止复制 document.addEventListener(copy,function(event){event.stopImmediatePropagation();},true); 2.解除禁止鼠标右键 document…...

如何把未量化的 70B 大模型加载到笔记本电脑上运行?

并行运行 70B 大模型 我们已经看到&#xff0c;量化已经成为在低端 GPU&#xff08;比如 Colab、Kaggle 等&#xff09;上加载大型语言模型&#xff08;LLMs&#xff09;的最常见方法了&#xff0c;但这会降低准确性并增加幻觉现象。 那如果你和你的朋友们把一个大型语言模型分…...

xwiki的权限-页面特殊设置>用户权限>组权限

官方文档https://www.xwiki.org/xwiki/bin/view/Documentation/AdminGuide/Access%20Rights/ 他有组权限、用户权限、页面及子页面特别设置。 页面特殊设置 > 用户权限 > 组权限 XWiki提供了设置wiki范围内权限、细粒度页面级权限的能力&#xff0c;以及在需要更多控制的…...

Go语言比较递归和循环执行效率

一、概念 1.递归 递归是指一个函数在其定义中直接或间接调用自身的编程方法 。简单来说&#xff0c;就是函数自己调用自己。递归主要用于将复杂的问题分解为较小的、相同类型的子问题&#xff0c;通过不断缩小问题的规模&#xff0c;直到遇到一个最简单、最基础的情况&#x…...

Windows 图形显示驱动开发-WDDM 2.0功能_供应和回收更改

供应和回收更改 对于 Windows 显示驱动程序模型 (WDDM) v2&#xff0c;有关 套餐 和 回收 的要求正在放宽。 用户模式驱动程序不再需要在内部分配上使用套餐和回收。 空闲/挂起的应用程序将使用 Microsoft DirectX 11.1 中引入的 TrimAPI 删除驱动程序内部资源。 API 级别将继…...

MongoDB 新手笔记

MongoDB 新手笔记 1. MongoDB 1.1 概述 MongoDB 是一种 文档型数据库&#xff08;NoSQL&#xff09;&#xff0c;数据以类似 JSON 的 BSON 格式存储&#xff0c;适合处理非结构化或半结构化数据。 对比 MySQL&#xff1a; MySQL 是关系型数据库&#xff0c;数据以表格形式存…...

Pytorch查看神经网络结构和参数量

基本方法 print(model) print(type(model))# 模型参数 numEl_list [p.numel() for p in model.parameters()] total_params_mb sum(numEl_list) / 1e6print(fTotal parameters: {total_params_mb:.2f} MB) # sum(numEl_list), numEl_list print(sum(numEl_list)) print(numE…...

Pytorch Dataset问题解决:数据集读取报错DatasetGenerationError或OSError

问题描述 在huggingface上下载很大的数据集&#xff0c;用多个parquet文件的格式下载到本地。使用load_dataset加载的时候&#xff0c;进度条加载到一半会报错DatasetGenerationError: An error occurred while generating the dataset&#xff1b;如果加载为IterableDataset&…...

学习OpenCV C++版

OpenCV C 1 数据载入、显示与保存1.1 概念1.2 Mat 类构造与赋值1.3 Mat 类的赋值1.4 Mat 类支持的运算1.5 图像的读取与显示1.6 视频加载与摄像头调用1.7 数据保存 参考&#xff1a;《OpenCV4快速入门》作者冯 振 郭延宁 吕跃勇 1 数据载入、显示与保存 1.1 概念 Mat 类 : Ma…...

特权FPGA之PS/2键盘解码

0 故事背景 见过这种接口的朋友们&#xff0c;大概都已经成家立业了吧。不过今天我们不讨论这种接口的历史&#xff0c;只讲讲这种接口的设计。&#xff08;如果还没有成家的朋友也别生气&#xff0c;做自己想做的事情就对了&#xff01;&#xff09; 1 时序分析 数据帧格式如图…...

SpringBoot 接口限流Lua脚本接合Redis 服务熔断 自定义注解 接口保护

介绍 Spring Boot 接口限流是防止接口被频繁请求而导致服务器负载过重或服务崩溃的一种策略。通过限流&#xff0c;我们可以控制单位时间内允许的请求次数&#xff0c;确保系统的稳定性。限流可以帮助防止恶意请求、保护系统资源&#xff0c;并优化 API 的可用性&#xff0c;避…...

FPAG_BUFFER学习

在FPGA设计中&#xff0c;缓冲器&#xff08;Buffer&#xff09;是信号传输和管理的核心组件&#xff0c;用于处理输入/输出信号、时钟分配以及信号完整性。以下是FPGA中常见缓冲器的详细介绍&#xff0c;分类说明其功能、应用场景和设计注意事项&#xff1a; --- ### **1. 输…...

《认知觉醒》下篇·第六章第一节“清晰:一个观念,重构你的行动力” 总结

《认知觉醒》下篇第六章第一节“清晰&#xff1a;一个观念&#xff0c;重构你的行动力”的核心内容总结&#xff1a; 1. 清晰的力量&#xff1a;行动力的第一性原理 定义 清晰是对目标、路径和结果的明确认知&#xff0c;是破除拖延与内耗的核心前提。 模糊的代价&#xff1a; …...

idea手动创建resources文件夹

有时maven没有构建成功可能造成&#xff0c;resources文件夹不创建的现象 此时我们可以手动创建 手动创建...

Scala相关知识学习总结6

1、集合计算高级函数说明 - 过滤&#xff1a;遍历集合&#xff0c;提取满足特定条件的元素组成新集合。 - 转化/映射&#xff08;map&#xff09;&#xff1a;将集合里的每个元素应用到指定函数进行转换。 - 扁平化&#xff1a;文档未详细阐述其具体含义和操作。 - 扁平化映射&…...