【Redis面试点总结】
1、缓存
1.1、穿透
查询一个空数据,mysql也查不到也不会写入缓存可能导致多次请求数据库
方案一:缓存设空即可(可能发生数据不一致就是这条数据有了但此时缓存是空,消耗内存)
方案二:布隆过滤器(实现复杂,容易产生误判)


1.2、击穿
一个key缓存过期重建过程中来了大量请求,缓存无数据全来到了数据库
方案一:互斥锁(强一致、性能差、一个线程进来其他线程都得等待)

方案二:逻辑过期(高可用、性能优、不能保证数据一致性)

添加逻辑过期expire字段:

1.3、雪崩
同一时段大量key失效或redis宕机,导致大量请求来到数据库
方案一:给不同的key的TTL添加随机值
方案二:利用redis集群提高可用性(哨兵模式、集群模式)
方案三:缓存业务添加降级限流策略(nginx、gateway)
方案四:给添加多级缓存(Guava或Caffeine)
1.4、双写一致(mysql数据与redis同步)
当修改了数据库的数据,同时也要更新缓存的数据,缓存要与数据库数据保持一致
读操作:缓存命中直接返回、未命中查询数据库写入缓存设置超时时间
写操作:延时双删(删除缓存–>修改数据库–>删除缓存)(双删防止脏数据、延时为了让主从模式把数据同步到从节点,延时过程中可能出现脏数据不能保证强一致性)
分布式锁(强一致性):
- 共享锁:读锁readLock,加锁过后其他线程共享读操作

- 排他锁:独占锁writeLock,加锁过后阻塞其他线程读写操作,底层setnx保证同一时刻只能一个线程操作锁住的方法

1.5、持久化
1.5.1、RDB
Redis Database Backup file(redis数据备份文件、数据快照)把内存所有数据存到磁盘,当redis故障重启后从磁盘快速读取快照文件恢复数据:命令1、save2、bgsave(子进程),redis.config也可设置自动备份策略(bgsave)

1.5.2、AOF
Append Only File(追加文件)redis处理的每一个写命令都会记录在AOF文件,可以看作命令日志文件,AOF默认关闭,在redis.config配置文件把appendonly的值改为yes也可修改AOF文件的名称

由于AOF是记录命令,文件要比RDB大得多。且AOF会记录同一个key的多次写操作,但实际上只有最后一次才有意义。通过bgrewriteaof命令重写。也可在配置文件设置重写阈值。
对比:

1.6、数据过期策略
- 惰性删除:该key过期后不管它,当需要该key后检查是否过期,若过期就删掉,反之返回该key(对cpu友好,对内存不友好存在大量用不到的key一直占内存)
- 定期删除:每隔一段时间检查一定量的key,删除其中过期的key(SLOW、FAST)
==》redis默认两种策略配合使用
1.7、淘汰策略
当redis的内存不够用,此时再添加key那么redis会按照某一逻辑将内存中的数据删除掉

面试:数据库1000万数据,redis只能存20万,如何保证redis的数据都是热点数据?(LRU)
2、集群
2.1、主从
- 主从全量同步:


- 主从增量同步:

2.2、哨兵
实现主从集群的自动故障修复(监控、恢复、通知)
1秒一个ping,哨兵选主(slave-priority越小优先级越高,offset越大,优先级越高)
脑裂:由于网络波动,发现ping不了master,之后选了个slave作为master,这就出现了两个master,但client还是向老master写数据,老master网络恢复后,无新增数据的新master把自个数据同步到老master,那么就丢失了此段时间的数据。更改配置文件解决:

2.3、分片集群
多个master集群,每个master数据不同,一个master有多个slave,master之间通过ping相互心跳检测
解决海量数据存储问题、高并发写的问题
redis分片引入了哈希槽的概念,redis集群有16384个哈希槽,每个key通过 CRC16 hash校验后对16384取模来决定放置在那个槽,集群每个节点负责一部分hash槽

3、分布式锁
本地锁只对本地起作用,因为jvm限制
3.1、setnx
添加锁:SET lock value NX EX 10(过期时间防止死锁业务超时或服务宕机会自动释放锁)
释放锁:DEL key
控制锁时长:1.根据业务执行时间预估(不推荐)2.给锁续期(redisson)
3.2、redisson
执行流程,新特性重试机制高并发下增加分布式锁的使用性能

基于Lua脚本保证命令执行原子性

可重入:跟据线程id判断,add1与add2属于同一线程所以add2会获取到锁

利用hash结构记录线程id和重入次数

主从一致性:当获取锁业务没结束后突然redis主节点(写、改、删数据)宕机,数据没来得及同步到子节点(读数据),那么集群默认选出一个子节点当作主节点替换掉宕机的,当另一个请求获取锁也是能够获取成功的这样两个线程公用一把锁就丧失了锁的互斥性,可能出现脏数据,方案:RedLock(红锁)(复杂、性能差)
相关文章:
【Redis面试点总结】
1、缓存 1.1、穿透 查询一个空数据,mysql也查不到也不会写入缓存可能导致多次请求数据库 方案一:缓存设空即可(可能发生数据不一致就是这条数据有了但此时缓存是空,消耗内存) 方案二:布隆过滤器&#x…...
打卡智能中国(五):博士都去哪儿了?
《打卡智能中国》系列更新了几期,有读者表示,很爱看这类接地气的真实故事,也有读者反映,不是电工,就是文员、农民、治沙人,人工智能不是高精尖学科吗?那些学历很高的博士都去哪儿了?…...
[Nacos] Nacos Client获取调用服务的提供者列表 (四)
文章目录 1.Nacos Client获取调用服务的提供者列表1.1 从Ribbon的负载均衡入手到Nacos Client获取调用服务的提高者列表1.2 getServers方法返回分析1.3 通过selectInstances方法查找Instances实例1.4 获取到要调用服务的serviceInfo Nacos Client 从Ribbon负载均衡调用服务。 …...
gcc编译一个程序的步骤(嵌入式学习)
1.预处理(Preprocessing): 在这个步骤中,预处理器将处理与#相关的代码,包括展开头文件、删除无用定义和替换宏定义。预处理器会生成一个经过宏替换和条件编译处理的中间文件。 gcc -E xxx.c -o xxx.i2.编译࿰…...
邹检验,结构变化识别及其R语言实现
在描述多维数据的维度关系时,线性模型无疑应用最多。然而某些情况下,我们关心随着时间变化或随着样本分组,线性关系的具体参数是否发生了变化,即是否发生结构变化Structural break。邹检验Chow test提供了最基本的一种结构变化显著…...
腾讯云,物联网开发平台产品,动态注册步骤
1. 下载后解压,qcloud_iot_mqtt_sign-master.zip GitHub - tencentyun/qcloud_iot_mqtt_signContribute to tencentyun/qcloud_iot_mqtt_sign development by creating an account on GitHub.https://github.com/tencentyun/qcloud_iot_mqtt_sign 2. 按照readme文…...
Padding, Spacer, Initializer 的使用
1. Padding 的使用 1.1 样式一 1) 实现 func testText1()-> some View{Text("Hello, World!").background(Color.yellow) // 背景颜色//.padding() // 默认间距.padding(.all, 10) // 所有的间距.padding(.leading, 20) // 开始的间距.ba…...
少儿编程 中国电子学会图形化编程等级考试Scratch编程四级真题解析(判断题)2023年3月
2023年3月scratch编程等级考试四级真题 判断题(共10题,每题2分,共20分) 11、在使用自定义积木时,不可以传递布尔型参数 答案:错 考点分析:考查自定义积木的使用,使用自定义积木的时候可以传递数字、文本和布尔型参数,所以错误 12、执行如下图程序后,输出的结果为“…...
Makefile学习笔记
目录 一、概述 1.1 Makefile 介绍 1.2规则 1.3核心 1.4示例 1.5定义命令 1.6 make是如何工作的 1.7、makefile中使用变量 1.8让make自动推导 1.9、另类风格的makefile 1.10、清空目标文件的规则 二、Makefile 总述 2.1、Makefile里有什么? 2.2、 mak…...
C++ 函数模板基础
文章目录 一、什么是函数模板二、函数模板的优点1、代码重用2、类型安全3、可读性4、泛型编程5、性能优化6、库开发 三、函数模板的使用场景1、通用操作2、数据结构与容器操作3、排序与查找算法4、数学与统计函数5、类型转换器6、自定义函数对象 四、模板参数的声明(…...
CUDA torch reinstall 与杂谈
一 实用技巧 1 从cuda11升级到12 apt-get --purge remove "cuda*" wget https://developer.download.nvidia.com/compute/cuda/12.1.1/local_installers/cuda_12.1.1_530.30.02_linux.run sh cuda_12.1.1_530.30.02_linux.run vim ~/.bashrc export PATH/usr/local…...
[230530] 托福TPO口语真题| TPO66~TPO72|XPO|Task1|20:30~21:00
目录 真题 预测题 真题 66. Do you agree or disagree with the following statement? Some people believe that a person needs a college education in order to have a successful career. Others believe that a college education is not necessary for…...
【FMC201】基于FMC标准的1路CameraLink Full 输入 子卡模块
产品概述 FMC201是一款CameraLink信号输入(采集)FMC子卡模块,该模块支持2路CameraLink Base模式或者1路CameraLink Full模式的图像信号输入。板卡具有2个CameraLink端口(SDR26),可以作为采集卡使用。 技术指…...
C语言_VS系列编译器写C语言或C++代码产生的一些错误与警告的解决方法(VS2010/VS2019)
本次来分享在用VS系列编译(VS2010/VS2019)写C语言或C代码时会遇到的一些警告和错误,提供博主的一些解决方法,若有更好的解决方法,大家也可以在评论区发表自己的意见噢,话不多说,开始上菜: 此博主在CSDN发布…...
从零实现一个数据库(DataBase) Go语言实现版 0.介绍
英文源地址 数据库实现步骤细分 1.持久化(Persistence) 我们为什么需要数据库?为什么不是直接把数据dump进文件中. 第一个话题就是持久化. 我们将讨论如果写入文件的过程中程序崩溃了, 或者电源断电了, 文件的状态会是什么样的呢? 文件是否只是丢失了最后一次写操作?或者…...
操作系统-X18 linux日志审计
Linux日志审计 在unix/类unix(Linux)系统中,日志是内核(内存)的一部分。 用于记录系统、程序运行中发生的各种事件 通过阅读日志,有助于诊断和解决系统故障 日志文件的分类 ①内核及系统日志 由系统sysl…...
【Vue工程】011-Axios
【Vue工程】011-Axios 文章目录 【Vue工程】011-Axios一、概述1、简介2、官网3、訾博其他相关博客【axios】001-axios概述、特点、文档说明【axios】002-axios发起请求axios封装 二、基本使用1、安装2、创建一个 token 状态3、axios 封装4、使用示例设置 baseURL请求调用拦截器…...
Cy7 NHS ester水溶性七甲川花菁染料标记活性脂477908-53-5
Sulfo-CY7 NHS ester是一种荧光标记试剂,可用于生物分子的荧光标记。它是一种水溶性的N-羟基琥珀酰亚胺酯化合物,具有强烈的荧光信号和高度稳定性。Sulfo-CY7 NHS ester的化学结构为C43H48N3NaO16S2,分子量约为968.98 g/mol。Sulfo-CY7 NHS e…...
利用CX-ONE搭建omron PLC仿真环境
目录 1 安装参考 2 CX-Simulator 2.1 打开软件 2.2 选择PLC配置文件存放位置 2.3 选择PLC类型 2.4 PLC Unit全部选择 2.5 设置FINS通讯 2.6 设置串口通讯 2.7 建立连接 3 CX-Programmer 3.1 新建工程 3.2 设置PLC型号 3.3 设置网络类型 3.4 设置串口通讯 3.5 设…...
webpack Plugin Loader
本文作者为 360 奇舞团前端开发工程师 webpack是Javascript工具链的关键部分。webpack是个用于现代JavaScript应用程序的静态模块打包工具。它不仅可以支持ESM和CommonJS模块化编程,而且还可以支持或扩展支持许多不同的静态资源,例如:Files,I…...
Unity ObjectPool性能优化实战:从基础使用到高频对象管理
1. 为什么需要对象池?游戏性能的隐形杀手 在开发射击类游戏或AR应用时,最影响性能的往往不是华丽的特效,而是那些看似简单的对象创建与销毁操作。想象一下这样的场景:玩家每秒发射20发子弹,每发子弹存活2秒,…...
为什么你的Django微服务总在凌晨OOM?揭秘企业级Python内存生命周期管理的7个致命盲区
第一章:Django微服务OOM现象的典型特征与根因图谱Django微服务在容器化部署场景下频繁触发OOM Killer,往往并非源于单次请求的内存爆炸,而是由内存泄漏累积、异步任务失控、序列化反模式及ORM懒加载滥用等多因素交织所致。典型表现包括&#…...
智能售后工单分类:EcomGPT-7B+NLP多标签分类
智能售后工单分类:EcomGPT-7BNLP多标签分类 电商售后每天涌入数千张工单,人工分类处理需要4小时,现在只需30分钟 每天早晨,电商客服团队都要面对堆积如山的售后工单。商品质量问题、物流投诉、退款申请、技术咨询……各种问题混杂…...
2026微型激光甲烷手持仪:行业标准、技术演进与全场景监测应用
在“双碳”目标与本质安全管理的双重驱动下,甲烷排放监测已从单一的“合规要求”跃升为能源、工业及市政领域的战略核心。微型激光甲烷手持仪作为基于可调谐激光吸收光谱技术(TDLAS)的尖端感知设备,正凭借其毫秒级响应、非接触遥测…...
OpenClaw多模态探索:千问3.5-9B处理图文混合任务
OpenClaw多模态探索:千问3.5-9B处理图文混合任务 1. 为什么需要多模态自动化助手 上周我在整理技术文档时遇到一个典型问题:需要根据包含屏幕截图和文字描述的故障报告,编写对应的排查步骤。手动在截图和文本之间来回切换,既低效…...
Xinference-v1.17.1视频内容审核系统实战
Xinference-v1.17.1视频内容审核系统实战 视频内容审核一直是内容平台面临的重要挑战,传统的人工审核方式效率低下且成本高昂。今天我们来体验一下基于Xinference-v1.17.1构建的视频内容审核系统,看看AI如何智能识别违规内容。 1. 系统核心能力展示 X…...
Java 并发原子类完全指南:Atomic 全家桶、CAS/JMM、ABA、LongAdder、源码阅读路线与经典实战
多线程编程中,count 这样简单的操作都不是线程安全的。用 synchronized 能解决问题,但锁会带来阻塞和上下文切换开销。java.util.concurrent.atomic 包提供了一套基于 CAS(Compare-And-Swap)的无锁并发工具,在“单变量…...
从零解析SHA-1:一个160位哈希的诞生之旅
1. 从原材料到成品:SHA-1的工厂流水线 想象你是一家精密零件加工厂的厂长,每天要处理各种形状不规则的金属原料(原始数据),最终需要生产出标准化的160位产品(哈希值)。SHA-1算法就像这条全自动生…...
Phi-4-mini-reasoning在中小学数学辅导中的应用:自动解题与答案验证
Phi-4-mini-reasoning在中小学数学辅导中的应用:自动解题与答案验证 1. 模型介绍 Phi-4-mini-reasoning是一款专注于推理任务的文本生成模型,特别擅长处理数学题、逻辑题等需要多步分析和简洁结论输出的场景。与通用聊天模型不同,它更专注于…...
Qwen3-ASR-0.6B快速入门:无需复杂配置,开箱即用体验
Qwen3-ASR-0.6B快速入门:无需复杂配置,开箱即用体验 想试试语音转文字,但被复杂的模型部署和配置劝退?今天给你介绍一个“傻瓜式”的语音识别工具——Qwen3-ASR-0.6B。它最大的特点就是简单,你不需要懂深度学习&#…...
