Redis----大key、热key解决方案、脑裂问题
文章中相关知识点在往期已经更新过了,如果有友友不理解可翻看往期内容
出现脑裂问题怎么保证集群还是高可用的
什么是脑裂问题
脑裂说的就是当我们的主节点没有挂,但是因为网络延迟较大,然后和主节点相连的哨兵通信较差,之后主从之间的同步就会受影响,主节点和哨兵之间的信号也不好,但是客户端和主节点之间还能进行通信,此时向主节点更新了一条数据,而由于网络问题,从节点未能同步,且由于哨兵集群和主节点之间的通信较差每次ping都收到主节点的恢复,那么哨兵集群就会判断主节点从主观下线到了客观下线(超过了设置的客观下线的数量),那么此时哨兵就会认为主节点挂了,此时会选取一个哨兵作为主节点,然后强行修改原来主节点的配置将其设置为该slave节点的从节点(然后向新的主节点发起主从同步的时候就会进行全量同步,因此原来主节点中更新的那个消息就会彻底丢失),但是此时的问题就是新的从节点并没有原来更新的那条数据的信息,这样就造成了数据的不一致。这就是脑裂问题
解决的核心思路就是
由于是因为主节点能处理客服端的更新操作和,网络延迟导致主从不一致,然后又由哨兵选取从节点变更为主节点导致的数据丢失,那么我们就可以采取这样的操作,即当发生这种网络延迟问题时,我们就拒绝客服端发过来的请求,这样就保证网络延迟期间主从的一致性,此时就算哨兵将从节点设置为新的主节点也没关系,因为数据被没有被更新,从节点中还是有所有数据
具体解决
具体解决就可以在配置文件中进行配置主节点发现从节点下线或者通信超时的总数量小于阈值
当主节点发现从节点下线或者通信超时的总数量小于阈值时,那么禁止主节点进行写数据,直接把错误返回给客户端。
在 Redis 的配置文件中有两个参数我们可以设置:
- min-slaves-to-write x,与主节点能连接的同的从节点个数只有超过x时才能进行写操作,否之拒绝写操作
- min-slaves-max-lag x,主从数据同步的延迟不能超过 x 秒,如果超过,主节点会禁止写数据。
我们可以把 min-slaves-to-write 和 min-slaves-max-lag 这两个配置项搭配起来使用,分别给它们设置一定的阈值,假设为 N 和 T。
这就表示这两个配置项组合后的要求是,主库连接的从库中至少有 N 个从库,和主库进行数据复制时的 ACK 消息延迟不能超过 T 秒,否则,主库就不会再接收客户端的写请求了。
大key、热key问题
大key
是什么?
Redis 中的 大 Key(Big Key) 是指存储的单个 Key 对应的 Value 过大(如字符串类型 Value 体积过大,或集合/列表/哈希等类型的元素数量过多)。这类 Key 会显著影响 Redis 的性能和稳定性,是实际应用中需要重点规避的问题。
大 Key 的典型场景
- 字符串类型
-
- 存储大体积数据(如 1MB 以上的 JSON/二进制数据)。
- 示例:缓存一个完整的商品详情页 HTML(可能达到几 MB)。
- 集合/列表/哈希类型
-
- 元素数量过多(如哈希表存储百万级字段)。
- 示例:用户粉丝列表存储了 100 万用户 ID。
- 流(Stream)类型
-
- 消息队列堆积未及时消费,导致单个流包含大量消息。
大key的危害
- 影响redis的持久化
- 客户端超时阻塞:由于redis执行命令是单线程的,然后再操作大key时会比较耗时,那么就会阻塞redis,从客户端这边看,就是很久很久没响应
- 引发网络阻塞。每次获取大key产生的流量都较大,比如假设一个key的大小是1MB,此时每秒访问量为1000MB,那么每秒就会产生1000MB的流量,这对于普通的千兆服务器来说是灾难性的
- 阻塞工作线程。如果使用了del命令删除了大key,就会阻塞工作线程可以采用unclink来异步删除
- 存储倾斜(内存分布不均):集群再slot分片均匀的情况下,会产生数据和查询倾斜的情况,存储大key的Redis节点占用内存多
这里讲一下为什么会影响redis的持久化
主要还是redis的fork以及写时复制这个原因
首先关于aof的刷盘策略:
- always:每次更新数据都进行刷盘,既每次都执行fsync()
- everysecond:每秒刷盘:会创建一个异步任务来执行fsync()
- no:数据到了aof buffer之后就不管了,由操作系统来进行控制刷盘,既永不执行fsync()函数
其实核心都是控制fsync()函数将内核缓冲区中的数据写到磁盘中
大key对于aof的持久化影响
如果设置的aof刷盘策略是Always策略,主线程再执行命令之后,会将数据写到AOF日志文件中,然后调用fsync()函数将内核缓冲区中的数据直接写到磁盘,等磁盘写操作完该函数才会返回,可以看到redis在这个过程中一直是阻塞等待的,即是单线程处理
所以在使用Always策略的时候,如果写入的是以一个大key,主线程执行fsync()函数的时候,阻塞时间会比较久,因为当写入的数据量很大的时候,数据会同步到磁盘这个过程很耗时
如果使用的是everysec或no的刷盘策略的话就持久化过程就不会影响主线程
大key对AOF重写和RDB的影响
1.对fork过程的影响
主要核心问题,AOF重写和RDB生成过程其实核心都是需要fork一个子进程,内核会将父进程中的页表也会复制一份给子进程,虽然子进程是独立运行的不影响主进程,但是在fork子进程的这个过程中是需要主进程参与的,
而大key说明所占空间比较大,也会导致页表所占空间增大,所以要是页表很大那么复制过程也是很耗时的,那么在fork时就会发生阻塞现象
2.因为在fork复制之后,主进程还会处理客户端的命令,如果客户端执行执行修改操作,那么主进程会进行写时复制操作(这个操作是主进程进行的),即将修改的数据拷贝一份到物理内存中,但如果修改的这个key就是大key那么这个复制过程也可能造成阻塞
-
- 示例:对字符串类型的大 Value 按固定大小分块存储(如
big_data:part1
,big_data:part2
)。
- 示例:对字符串类型的大 Value 按固定大小分块存储(如
- 对于海量数据存储时,我们也可以通过上面两种方式先进行拆分key,拆分key之后redis会计算key的哈希值去找到对应的哈希巢slot,然后将这个大key就将其拆成不同的小key,对应不同的哈希槽slot,然后就可以分布到不同的节点,这样就可以有效解决数据倾斜问题
热key问题
是什么
Redis 中的 热 Key(Hot Key) 是指被高频访问的单个 Key,其请求量远高于其他 Key。这类 Key 会导致 Redis 实例或某个分片(Cluster 模式)的负载过高,引发性能瓶颈甚至服务崩溃。热 Key 问题需要结合业务场景和架构设计来预防和解决。
热 Key 的危害
- 单节点过载(多级缓存+对key拆分解决)
-
- 在 Redis 集群模式下,热 Key 可能集中在某个分片(哈希槽),导致该节点 CPU/网络过载,而其他节点空闲。
- 示例:某商品库存 Key 每秒接收 10 万次读取,远超单节点处理能力。
- 缓存雪崩风险(一致性要求高就直接加分布式锁,否之可以使用key的逻辑过期)
-
- 若热 Key 突然失效(如过期或主动删除),大量请求穿透到数据库,可能引发级联故障。
- 性能抖动(参考大key问题)
-
- 热 Key 的频繁访问可能导致 Redis 主线程阻塞(如大 Value 读取),影响其他请求的延迟
解决方案
主要:本地缓存+热key的冗余话存储+读写分离,如果读多那么可以考虑增加从节点的个数
2. 压缩数据
- 对字符串类型的 Value 使用压缩算法(如 gzip、Snappy),读取时解压。
- 需权衡 CPU 与内存的消耗(适合读少写多的场景)。
3. 设置过期时间
- 对临时性大 Key 设置 TTL(如
EXPIRE
),避免长期占用内存。
4. 异步删除
- Redis 4.0+ 支持
UNLINK
命令替代DEL
,后台异步删除大 Key。 - 配置
lazyfree-lazy-user-del yes
,自动异步删除。
5. 限流与熔断
- 客户端对大 Key 的访问做限流(如令牌桶算法),避免突发流量压垮服务。
1. 本地缓存(多级缓存)
- 在应用层(客户端)对热 Key 添加本地缓存(如 Guava、Caffeine),减少对 Redis 的直接访问。
- 适用场景:读多写少,允许短暂数据不一致(设置较短的本地 TTL)。
- 示例:商品库存读取时,客户端缓存库存值 100ms,期间所有请求直接读本地缓存。
2. Key 分片(分散压力)
- 将热 Key 拆分为多个子 Key,通过哈希或随机后缀分散到不同节点。
-
- 示例:原 Key
stock:item_123
拆分为stock:item_123:1
、stock:item_123:2
,客户端随机访问一个子 Key。
- 示例:原 Key
- 注意:需确保数据一致性(如所有子 Key 同时更新)。
3. 读写分离
- 对热 Key 启用读写分离,将读请求分发到从节点(需容忍主从同步延迟)。
- 限制:Redis 集群模式下从节点不分担读请求(需 Proxy 或客户端分片)。
4. 缓存永不过期 + 异步更新
- 对热 Key 不设置过期时间,通过后台任务定期更新缓存,避免缓存击穿。
- 示例:商品库存每 10 秒异步更新一次,Key 永不过期。
5. 限流与熔断
- 对热 Key 的访问进行限流(如令牌桶算法),超出阈值时熔断,返回默认值或降级数据。
- 工具:使用 Sentinel、Hystrix 或 Resilience4j 实现。
6. 使用更高效的数据结构
- 优化存储格式,减少单次访问的数据量。
-
- 示例:用哈希表存储商品信息,按需获取字段(
HGET
替代GET
),避免传输冗余数据。
- 示例:用哈希表存储商品信息,按需获取字段(
7. Redis 集群扩容
- 对热 Key 所在的分片进行垂直扩容(提升单节点配置)或水平扩容(增加分片数量,需迁移数据)。
这里讲一下key分片策略
方案核心思想
- 冗余存储
将热 Key 复制多份,存储在不同的 Master 节点,例如key:1
(节点1)、key:2
(节点2)。 - 请求分发
客户端通过轮询或哈希算法,将请求均匀分发到不同副本,降低单个节点的压力。
适用场景
- 读多写少:写入频率低,且容忍一定同步延迟(如缓存热点新闻)。
- 高并发读:单 Key 的 QPS 远超单节点处理能力(如 10万+/秒)。
- 集群模式:Redis 部署为 Cluster 模式,且 Master 节点数量充足。
优势
- 分散读压力
读请求被均匀分发到多个节点,避免单节点过载。 - 高可用性
冗余副本分散在不同节点,单个节点故障时,其他副本仍可提供服务(需配合故障转移)。 - 扩展性
可通过增加副本数量(如key:3
、key:4
)应对更高并发。
潜在问题
1. 数据一致性
- 写入成本高:每次更新需同步修改所有副本,否则会读到旧数据。
-
- 示例:更新
key
时需同时更新key:1
、key:2
,若某次更新失败,会导致数据不一致。
- 示例:更新
- 最终一致性:若副本间同步有延迟,客户端可能读到不同版本的数据。
2. 额外存储开销
- 冗余副本占用更多内存,若 Key 的 Value 较大(如 1MB),存储成本显著增加。
3. 客户端复杂度
- 客户端需维护所有副本的位置(如
key:1
、key:2
),并实现负载均衡逻辑。 - 若集群拓扑变化(如节点扩容/缩容),客户端需动态感知副本分布。
4. 写入放大效应
- 对热 Key 的写入操作会放大 N 倍(N=副本数),可能引发性能问题。
优化方案
1. 异步复制(最终一致性)
- 写入时仅更新主副本(如
key:1
),通过后台任务异步同步到其他副本(如key:2
)。 - 代价:读可能短暂不一致,适合对一致性要求不高的场景(如计数器缓存)。
2. 版本号控制
- 为每个 Key 添加版本号(如
key:1:v100
、key:2:v100
),客户端读取时校验版本号,若不一致则触发同步。 - 示例:
-
- 写入时更新所有副本,并递增版本号。
- 读取时优先访问一个副本,若发现版本号落后,触发同步。
3. 代理层分发
- 使用中间件(如 Redis Proxy 或 Envoy)统一管理副本,客户端无感知。
-
- 代理层维护副本列表,自动负载均衡读请求。
- 写入时由代理层同步更新所有副本。
4. 结合读写分离
- 主副本(如
key:1
)处理写请求,其他副本(如key:2
、key:3
)作为只读副本。 - 读请求分发到只读副本,写入仅需更新主副本,降低一致性复杂度。
与其他方案的对比
方案 | 优点 | 缺点 | 适用场景 |
冗余分片 | 分散读压力,高可用 | 数据一致性难,写入成本高 | 读多写少,容忍最终一致性 |
本地缓存 | 零网络开销,响应快 | 数据不一致,内存占用高 | 极高频读,允许短暂不一致 |
Key 分片(Hash) | 天然分散压力,无需维护副本 | 拆分逻辑复杂,需修改业务代码 | 数据可拆分(如按用户 ID 分片) |
读写分离 | 利用从节点资源,简单易行 | 主从延迟,集群模式不支持 | 读占比高,容忍延迟 |
目前已更新系列:
当前:Redis----大key、热key解决方案、脑裂问题
分布式---raft算法
分布式---CAP&&BASE理论
MySQL----BufferPool、redolog binlog两阶段提交
实习期间git的分枝管理以及最常用的命令-CSDN博客
Redis高级-----持久化AOF、RDB原理
Redis高级---面试总结5种数据结构的底层实现
Redis高级----主从、哨兵、分片、脑裂原理-CSDN博客
Redis高级---面试总结内存过期策略及其淘汰策略
计算机网络--面试知识总结一
计算机网络-----面试知识总结二
计算机网络--面试总结三(Http与Https)
计算机网络--面试总结四(HTTP、RPC、WebSocket、SSE)-CSDN博客
计算机网络-------重传、TCP流量控制、拥塞控制_tcp拥塞控制,拥塞避免-CSDN博客
知识积累之ThreadLocal---InheritableThreadLocal总结
分布式ID多种生成方式-CSDN博客
并发编程之----线程池ThreadPoolExecutor,Excutors的使用及其工作原理
相关文章:
Redis----大key、热key解决方案、脑裂问题
文章中相关知识点在往期已经更新过了,如果有友友不理解可翻看往期内容 出现脑裂问题怎么保证集群还是高可用的 什么是脑裂问题 脑裂说的就是当我们的主节点没有挂,但是因为网络延迟较大,然后和主节点相连的哨兵通信较差,之后主…...
Android 调用c++报错 exception of type std::bad_alloc: std::bad_alloc
一、报错信息 terminating with uncaught exception of type std::bad_alloc: std::bad_alloc 查了那部分报错c++代码 szGridSize因为文件太大,初始化溢出了 pEGM->pData = new float[szGridSize]; 解决办法 直接抛出异常,文件太大就失败吧 最后还增加一个日志输出,给…...
【从零开始学习计算机科学】操作系统(五)处理器调度
【从零开始学习计算机科学】操作系统(五)处理器调度 处理器调度一些简单的短程调度算法的思路先来先服务(First-Come-First-Served,FCFS)优先级调度及其变种最短作业优先调度算法(SJF)--非抢占式最短作业优先调度算法(SJF)--抢占式最高响应比优先调度算法轮转调度算法…...
LeetCode1871 跳跃游戏VII
LeetCode 跳跃游戏 IV:二进制字符串的跳跃问题 题目描述 给定一个下标从 0 开始的二进制字符串 s 和两个整数 minJump 和 maxJump。初始时,你位于下标 0 处(保证该位置为 0)。你需要判断是否能到达字符串的最后一个位置…...
ResNet50深度解析:原理、结构与PyTorch实现
ResNet50深度解析:原理、结构与PyTorch实现 1. 引言 ResNet(残差网络)是深度学习领域的一项重大突破,它巧妙解决了深层神经网络训练中的梯度消失/爆炸问题,使得构建和训练更深的网络成为可能。作为计算机视觉领域的里…...
MATLAB 控制系统设计与仿真 - 24
PID 控制器分析- 控制器的形式 连续控制器的结构: 为滤波时间常数,这类PID控制器在MATLAB系统控制工具箱称为并联PID控制器,可由MATLAB提供的pid函数直接输入,格式为: 其他类型的控制器也可以由该函数直接输入&#x…...
数字IC后端设计实现教程 |Innovus ICC2 Routing Pin Access Setting设置方法
默认情况下routing 引擎可以在标准单元可以打孔的任何地方(via region)打孔,甚至工具还会先拉出一块metal,然后再打孔过渡到高层。 随之工艺节点越做越小,标准单元内部的结构也越来越复杂。此时如果还沿用传统工艺的走…...
mysql经典试题共34题
1、准备数据 -- drop drop table if exists dept; drop table if exists emp; drop table if exists salgrade;-- CREATE CREATE TABLE dept (deptno int NOT NULL COMMENT 部门编号,dname varchar(14) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci DEFAULT NULL COMM…...
网络编程-----服务器(多路复用IO 和 TCP并发模型)
一、单循环服务器模型 1. 核心特征 while(1){newfd accept();recv();close(newfd);}2. 典型应用场景 HTTP短连接服务(早期Apache)CGI快速处理简单测试服务器 3. 综合代码 #include <stdio.h> #include <sys/types.h> /* See NO…...
GitHub 项目版本管理与 Release 发布流程记录
GitHub 项目版本管理与 Release 发布流程记录 1. 项目环境设置 1.1 打开 VS Code 并进入项目目录 E:\adb\Do>code .1.2 配置 Git 用户信息 E:\adb\Do>git config --global user.name "n" E:\adb\Do>git config --global user.email "**gmail.com&q…...
GStreamer —— 2.15、Windows下Qt加载GStreamer库后运行 - “播放教程 1:Playbin 使用“(附:完整源码)
运行效果 介绍 我们已经使用了这个元素,它能够构建一个完整的播放管道,而无需做太多工作。 本教程介绍如何进一步自定义,以防其默认值不适合我们的特定需求。将学习: • 如何确定文件包含多少个流,以及如何切换 其中。…...
Python+DeepSeek:开启AI编程新次元——从自动化到智能创造的实战指南
文章核心价值 技术热点:结合全球最流行的编程语言与国产顶尖AI模型实用场景:覆盖代码开发/数据分析/办公自动化等高频需求流量密码:揭秘大模型在编程中的创造性应用目录结构 环境搭建:5分钟快速接入DeepSeek场景一:AI辅助代码开发(智能补全+调试)场景二:数据分析超级助…...
使用OpenCV和MediaPipe库——驼背检测(姿态监控)
目录 驼背检测的运用 1. 驾驶姿态与疲劳关联分析 2. 行业应用案例 1. 教育场景痛点分析 2. 智能教室系统架构 代码实现思路 1. 初始化与配置 2. MediaPipe和摄像头设置 3. 主循环 4. 资源释放 RGB与BGR的区别 一、本质区别 二、OpenCV的特殊性 内存结构示意图&…...
maven的项目构建
常用构建命令 命令说明mvn clean清理编译结果(删掉target目录)mvn compile编译核心代码,生成target目录mvn test-compile编译测试代码,生成target目录mvn test执行测试方法mvn package打包,生成jar或war文件mvn insta…...
光电感知赋能智能未来 灵途科技护航新质生产力发展
2024年《政府工作报告》将大力推进现代化产业体系建设,加快发展新质生产力作为首要工作任务。这是“新质生产力”首次出现在《政府工作报告》中。 发展新质生产力具体包括 新兴产业 :推动商业航天、低空经济等新兴产业实现安全健康发展。 未来产业 &a…...
文件上传靶场(10--20)
目录 实验环境: 具体内容实现: 第十关(双写绕过): 第十一关:(%00截断,此漏洞在5.2版本中) 正确用法 错误用法 思路: 操作过程: 第十二关…...
deepseek在pycharm中的配置和简单应用
对于最常用的调试python脚本开发环境pycharm,如何接入deepseek是我们窥探ai代码编写的第一步,熟悉起来总没坏处。 1、官网安装pycharm社区版(免费),如果需要安装专业版,需要另外找破解码。 2、安装Ollama…...
Linux 生成静态库
文章目录 前提小知识生成和使用.a库操作步骤 在应用程序中,有一些公共的代码需要反复使用的,可以把这些代码制作成“库文件”;在链接的步骤中,可以让链接器在“库文件”提取到我们需要使用到的代码,复制到生成的可执行…...
yolo-TensorRT相关代码逐步详解-pt转engine
基于TensorRT 的推论运行速度会比仅使用CPU 快40倍,提供精度INT8 和FP16 优化,支援TensorFlow、Caffe、Mxnet、Pytorch 等深度学习框架,其中Mxnet、Pytorch 需先转换为ONNX 格式。 TensorRT的构建流程大致分为几个步骤:创建构建器和网络、解析模型、配置构建参数、构建引擎…...
简记_ MCU管脚的防静电处理
一、分析(一) 接口处的信号要先过 ESD/TVS 管,然后拉到被保护器件; 建个 ESD 电路发生器的模型,代入到我们的电路中去分析: 继电器实现这两个“开关”,并且还会感应出一些额外的RLC寄生。 ES…...
C语言实现算法(二)
以下是 “10个不重复的C语言经典算法案例“,包含可运行代码、开发环境配置及系统要求。所有代码基于标准C语法,已在GCC 9.3.0环境下测试通过。 开发环境配置 编译器:GCC(推荐) Windows:安装 MinGW 或 Visual Studio Linux:sudo apt-get install gcc macOS:通过Xcode Co…...
transformer模型介绍——大语言模型 LLMBook 学习(二)
1. transformer模型 1.1 注意力机制 **注意力机制(Attention Mechanism)**在人工智能中的应用,实际上是对人类认知系统中的注意力机制的一种模拟。它主要模仿了人类在处理信息时的选择性注意(Selective Attention)&a…...
K8s 1.27.1 实战系列(十一)ConfigMap
ConfigMap 是 Kubernetes 中管理非敏感配置的核心资源,通过解耦应用与配置实现灵活性和可维护性。 一、ConfigMap 的核心功能及优势 1、配置解耦 将配置文件(如数据库地址、日志级别)与容器镜像分离,支持动态更新而无需重建镜像。 2、多形式注入 环境变量:将键值…...
下降路径最⼩和(medium)
题目描述: 给你一个 n x n 的 方形 整数数组 matrix ,请你找出并返回通过 matrix 的下降路径 的 最小和 。 下降路径 可以从第一行中的任何元素开始,并从每一行中选择一个元素。在下一行选择的元素和当前行所选元素最多相隔一列(…...
数据结构--【顺序表与链表】笔记
顺序表 template <class T> class arrList :public List<T> //表示 arrList 类以公有继承的方式继承自 List<T> 类 //公有继承意味着 List<T> 类的公共成员在 arrList 类中仍然是公共成员,受保护成员在 arrList 类中仍然是受保护成员。 { …...
使用AI一步一步实现若依前端(9)
功能9:退出登录功能 功能8:页面权限控制 功能7:路由全局前置守卫 功能6:动态添加路由记录 功能5:侧边栏菜单动态显示 功能4:首页使用Layout布局 功能3:点击登录按钮实现页面跳转 功能2…...
Excel两列和依次相减
Excel实现左列依次行数的和减去右列依次行数的和: 举例:结余SUM(预付款)-SUM(开支) 公式:SUM($B$2:B2)-SUM($C$2:C2)...
智能合约中权限管理不当
权限管理不当 : 权限管理不当是智能合约中常见的安全问题之一,尤其是在管理员或特定账户被过度赋予权限的情况下。如果合约中的关键功能,如转移资产、修改合约状态或升级合约逻辑,可以被未经授权的实体随意操作,这将构…...
Java糊涂包(Hutool)的安装教程并进行网络爬虫
Hutool的使用教程 1:在官网下载jar模块文件 Central Repository: cn/hutool/hutool-all/5.8.26https://repo1.maven.org/maven2/cn/hutool/hutool-all/5.8.26/ 下载后缀只用jar的文件 2:复制并到idea当中,右键这个模块点击增加到库 3&…...
ubuntu软件
视频软件,大部分的编码都能适应 sudo apt install vlc图片软件 sudo apt install gwenview截图软件 sudo apt install flameshot设置快捷键 flameshot flameshot gui -p /home/cyun/Pictures/flameshot也就是把它保存到一个自定义的路径 菜单更换 sudo apt r…...
python高效试用17---两个字符串组成一个新的字符串和两个字符串组成元组作为key哪个更高效
在 Python 中,使用字符串连接 (str1 str2) 作为 key 和使用元组 ((str1, str2)) 作为 key 的效率差异,主要受以下因素影响: 哈希计算速度: 字符串连接 (str1 str2):会创建一个新的字符串对象,并计算哈希…...
【C++模板】:开启泛型编程之门(函数模版,类模板)
📝前言: 在上一篇文章C内存管理中我们介绍了C的内存管理,重点介绍了与C语言的区别,以及new和delete。这篇文章我们将介绍C的利器——模板。 在C编程世界里,模板是一项强大的特性,它为泛型编程奠定了坚实基础…...
华为eNSP:2.配置OSPF报文分析和验证
一、OSPF的5种数据包 Hello包:用于发现和维护邻居关系。定期发送,确保邻居路由器在线。 数据库描述包(DBD, Database Description Packet):在邻居关系建立后,用于交换链路状态数据库的摘要信息。 链路状…...
一学就会的深度学习基础指令及操作步骤(3)模型训练验证
文章目录 模型训练验证损失函数和优化器模型优化训练函数验证函数模型保存 模型训练验证 损失函数和优化器 loss_function nn.CrossEntropyLoss() # 损失函数 optimizer Adam(model.parameters()) # 优化器,优化参数模型优化 获得模型所有的可训练参数&#x…...
【病毒分析】熊猫烧香病毒分析及其查杀修复
目录 前言 一、样本概况 1.1 样本信息 1.2 测试环境及工具 1.3 分析目标 二、具体行为分析 2.1 主要行为 2.1.1 恶意程序对用户造成的危害 2.2 恶意代码分析 2.2.1 加固后的恶意代码树结构图(是否有加固) 2.2.2 恶意程序的代码分析片段 三、解决方案(或总结) 3.1 …...
K8s 1.27.1 实战系列(九)Volume
一、Volume介绍 Volume 指的是存储卷,包含可被Pod中容器访问的数据目录。容器中的文件在磁盘上是临时存放的,当容器崩溃时文件会丢失,同时无法在多个Pod中共享文件,通过使用存储卷可以解决这两个问题。 1、Volume 的核心作用 数据持久化与生命周期管理 Volume 的核心目标…...
火绒企业版V2.0全面支持Linux与国产化系统!免费试用助力国产化终端安全升级
国产化浪潮下的安全新挑战 随着信创产业的加速推进,国产操作系统(统信UOS、麒麟OS等)和ARM架构服务器逐步成为政企核心业务的基础设施。然而,针对国产化系统的勒索攻击、网页篡改、供应链漏洞等威胁频发,传统安全方案…...
黑色RGB是什么
>好的,用户现在问的是“黑色rgb是什么”。我需要先理解用户的问题。之前用户在使用MATLAB调整网格线颜色时,可能看到了默认颜色是黑色,或者之前我提到过默认颜色是[0.15 0.15 0.15],而用户可能现在想知道黑色的RGB值具体是什么…...
基于springboot+vue的佳途旅行分享预约平台
一、系统架构 前端:vue2 | element-ui | html 后端:springboot | mybatis-plus 环境:jdk1.8 | mysql | maven | node 二、代码及数据库 三、功能介绍 01. web端-注册 02. web端-登录 03. web端-系统主页1 04. web端-系统主页2 05. we…...
Nuxt3 ssr build/dev时区分不同的环境
package.json "scripts": {"build": "nuxt build --dotenv .env.prod","build:dev": "nuxt build --dotenv .env.dev","postbuild": "mv -f .output ./dist/.output", //支持自定义文件名"dev&quo…...
利用OpenResty拦截SQL注入
需求 客户的一个老项目被相关部门检测不安全,报告为sql注入。不想改代码,改项目,所以想到利用nginx去做一些数据校验拦截。也就是前端传一些用于sql注入的非法字符或者数据库的关键字这些,都给拦截掉,从而实现拦截sql…...
保姆级别使用Python实现“机器学习“案例
从安装到运行手把手教学,保证不迷路~ 🌈 零基础友好版教程 📦 第一步:安装必备工具包 别慌!这里有两种安装方式,选你顺手的 方式1:用代码自动安装(推荐新手) 直接在你的Python代码最前面加这几行,运行时会自动安装: # 把这坨代码贴在文件最前面! import sys im…...
【最新】DeepSeek 实用集成工具有那些?
deepseek 系列github仓库地址 【主页】deepseek-aiDeepSeek-R1DeepSeek-V3DeepSeek-VL2【本文重点介绍】awesome-deepseek-integration 注意:以下内容来自awesome-deepseek-integration DeepSeek 实用集成(awesome-deepseek-integration) 将…...
【前端面试题】Vu3常见的面试题
1.Vue3与 Vue2的核心区别有哪些? 响应式系统 : Vue2:通过Object.defineProperty 实现响应式。这种方式在处理对象属性的添加和删除时存在局限性,且无法直接监控数组的变化 ;Vue3:采用Proxy 实现响应式&…...
论文阅读分享——UMDF(AAAI-24)
概述 题目:A Unified Self-Distillation Framework for Multimodal Sentiment Analysis with Uncertain Missing Modalities 发表:The Thirty-Eighth AAAI Conference on Artificial Intelligence (AAAI-24) 年份:2024 Github:暂…...
JavaWeb——Mybatis、JDBC、数据库连接池、lombok
一、Mybatis 目录 一、Mybatis 二、JDBC 三、数据库连接池 1.概述 2.优势 3.标准接口 4.常见产品 四、lombok 1.概述 2.导入依赖 3.注解 创建步骤: 1.准备工作(创建springboot工程、数据库表user、实体类User) 2.引入Mybatis的相关依赖&am…...
【网络安全工程】任务12:网络安全设备
目录 一、防火墙 1、作用 2、配置方式 3、存在的漏洞 二、入侵检测系统(IDS)和入侵防御系统(IPS) 1、作用 2、配置方式 3、存在的漏洞 三、防病毒网关 1、作用 2、配置方式 3、存在的漏洞 …...
【学习笔记】《逆向工程核心原理》02.小段标记法、IA-32寄存器、栈、abex‘crackme、栈帧
文章目录 1. 字节序1.1. 大端序与小端序1.2. 在OllyDbg中查看小端序 2.IA-32寄存器2.1. 什么是CPU寄存器2.2. IA-32寄存器2.2.1. 通用寄存器2.2.2. 段寄存器2.2.3. 程序状态与控制寄存器2.2.4. 指令指针寄存器 3. 栈1.1. 栈的特征3.1.2. 栈操作实例 4. abexcrackme4.1. 开始调试…...
固定表头、首列 —— uniapp、vue 项目
项目实地:也可以在 【微信小程序】搜索体验:xny.handbook 另一个体验项目:官网 一、效果展示 二、代码展示 (1)html 部分 <view class"table"><view class"tr"><view class&quo…...
用友U9二次开发-问题记录
学习资料:链接: https://pan.baidu.com/s/13JbKSSRkSn2V6-dYX5zKFQ 提取码: p9at 页面 &__dmtrue 客开插件 &Admintrue 开发者使用查看代码 插件 UI插件配置项 1.关闭热插拔 2.在configuration节点下加配置,多个在Web…...