Redis面试高频三大问-缓存穿透、缓存击穿、缓存雪崩

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis面试高频三大问-缓存穿透、缓存击穿、缓存雪崩

我通俗易懂的讲给你听,保证你一次记住

缓存穿透

穿透,如下图

image.gif编辑

客户端访问缓存, 缓存没数据,要去数据库查询, 数据库也没有, 频繁大量的这种查询请求,就穿透了,导致库崩了。

解决方案

1.访问一次,如果缓存层和数据库都没有,就在缓存层存一个对象, 下次访问就不用访问库了。

      缺点:可能会存储很多的对象,浪费空间。

2.加布隆过滤器,就是一种数据结构, 一个长度m的 bit位数组 + n 个hash函数组成的数据结构。

说白了就是把数据库的数据在 这个数组做个标记, 先去缓存查数组,数组没这个标记说明没这条数据,就不去访问数据库了。

       缺点:可能会出现标记显示的有,但是实际上没有的情况,但是这是偶然概率。如果标记显示没有就一定没有。

缓存击穿

击穿,并没有穿透, 如下图

image.gif编辑

没有透过数据库,说明数据库有数据。

缓存在内存,可能会过期,如果在某一时间查询的时候,缓存中的数据过期了,是不是就需要到数据库查,这个时候大量的请求会把数据库访问崩。

解决方案

1.设置永不过期的key,或者设置过期时间,同时启动定时任务去定时去更新这个缓存。

2.加锁,同一时间只有一个线程可以获取到锁,获得锁的线程去数据库把数据加载到内存。

缓存雪崩

雪崩就是全完蛋了,直接上图

image.gif编辑

如果redis崩了,或者在同一时间大量的Key过期了,是不是就不走缓存了,直接访问数据库了,直接访问数据请求太多的话,数据就有可能崩。

解决方案

1.高可用呗,做集群,一个崩了,有其他的顶上。

2.限流组件开启,高并发给一部分请求降降级,限限流。

3.避免同一时间大量的Key过期,那就 随机设置过期时间,过期时间长点,或者设置永不过期。

4.redis可内存可持久化没忘了吧, 把持久化开启,发生雪崩就从RDB和AOF文件中恢复。

ps:来自大山放牛的孩子,追求更高更牛的技术。

      如果文章对你有帮助,点个关注吧!

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1月前
|
存储 NoSQL Java
可能是最漂亮的Redis面试基础详解
我是南哥,相信对你通关面试、拿下Offer有所帮助。敲黑板:本文总结了Redis基础最常见的面试题!包含了Redis五大基本数据类型、Redis内存回收策略、Redis持久化等。相信大部分Redis初学者都会忽略掉一个重要的知识点,Redis其实是单线程模型。我们按直觉来看应该是多线程比单线程更快、处理能力更强才对,比如单线程一次只可以做一件事情,而多线程却可以同时做十件事情。但Redis却可以做到每秒万级别的处理能力,主要是基于以下原因:(1)Redis是基于内存操作的,Redis所有的数据库状态都保存在
可能是最漂亮的Redis面试基础详解
|
20天前
|
NoSQL Java API
美团面试:Redis锁如何续期?Redis锁超时,任务没完怎么办?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴在面试一线互联网企业时遇到了关于Redis分布式锁过期及自动续期的问题。尼恩对此进行了系统化的梳理,介绍了两种核心解决方案:一是通过增加版本号实现乐观锁,二是利用watch dog自动续期机制。后者通过后台线程定期检查锁的状态并在必要时延长锁的过期时间,确保锁不会因超时而意外释放。尼恩还分享了详细的代码实现和原理分析,帮助读者深入理解并掌握这些技术点,以便在面试中自信应对相关问题。更多技术细节和面试准备资料可在尼恩的技术文章和《尼恩Java面试宝典》中获取。
美团面试:Redis锁如何续期?Redis锁超时,任务没完怎么办?
|
26天前
|
NoSQL 算法 Redis
Redis面试篇
Redis面试篇
34 5
|
27天前
|
缓存 NoSQL Java
Java中redis面试题
Java中redis面试题
32 1
|
7天前
|
存储 NoSQL Redis
Redis常见面试题:ZSet底层数据结构,SDS、压缩列表ZipList、跳表SkipList
String类型底层数据结构,List类型全面解析,ZSet底层数据结构;简单动态字符串SDS、压缩列表ZipList、哈希表、跳表SkipList、整数数组IntSet
|
1月前
|
NoSQL Redis
redis 的 key 过期策略是怎么实现的(经典面试题)超级通俗易懂的解释!
本文解释了Redis实现key过期策略的方式,包括定期删除和惰性删除两种机制,并提到了Redis的内存淘汰策略作为补充,以确保过期的key能够被及时删除。
48 1
|
25天前
|
缓存 NoSQL 算法
面试题:Redis如何实现分布式锁!
面试题:Redis如何实现分布式锁!
|
3月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
28天前
|
算法 Java 数据中心
探讨面试常见问题雪花算法、时钟回拨问题,java中优雅的实现方式
【10月更文挑战第2天】在大数据量系统中,分布式ID生成是一个关键问题。为了保证在分布式环境下生成的ID唯一、有序且高效,业界提出了多种解决方案,其中雪花算法(Snowflake Algorithm)是一种广泛应用的分布式ID生成算法。本文将详细介绍雪花算法的原理、实现及其处理时钟回拨问题的方法,并提供Java代码示例。
59 2
|
1月前
|
JSON 安全 前端开发
第二次面试总结 - 宏汉科技 - Java后端开发
本文是作者对宏汉科技Java后端开发岗位的第二次面试总结,面试结果不理想,主要原因是Java基础知识掌握不牢固,文章详细列出了面试中被问到的技术问题及答案,包括字符串相关函数、抽象类与接口的区别、Java创建线程池的方式、回调函数、函数式接口、反射以及Java中的集合等。
26 0