[Redis详解]----缓存击穿

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 缓存击穿是指当一个Key的缓存即将过期或者已经过期时,大量的请求同时访问该Key,由于缓存中不存在该Key,所有请求都会去后端数据源获取数据,导致后端数据源压力瞬间增大,甚至崩溃。缓存击穿通常发生在缓存和后端数据源的过期时间相差不大的情况下,因为这样会导致大量的请求同时访问后端数据源.注:有的朋友不能理解为什么刚好一个缓存过期的时候就很多请求进来,其实是这个数据一直都有很多请求,例如网站的首页,热点数据等等.


介绍:

       缓存击穿是指当一个Key的缓存即将过期或者已经过期时,大量的请求同时访问该Key,由于缓存中不存在该Key,所有请求都会去后端数据源获取数据,导致后端数据源压力瞬间增大,甚至崩溃。缓存击穿通常发生在缓存和后端数据源的过期时间相差不大的情况下,因为这样会导致大量的请求同时访问后端数据源.

注:有的朋友不能理解为什么刚好一个缓存过期的时候就很多请求进来,其实是这个数据一直都有很多请求,例如网站的首页,热点数据等等.

解决方案:
1、互斥锁:

       存在的问题 : 同一时间的请求有一个在进行更新缓存操作,其他的都在休眠重试,效率很低,反应到业务上就是所有人查询到这一块会卡顿一下.

2、逻辑过期:

         这种方式和互斥锁类似,只不过更新数据多开了一个线程,其他的请求发现逻辑时间过期就直接返回旧数据,从业务上来说并不会产生卡顿,只有是数据更新时间慢了一点点,一般情况下用户是感受不到的

相关实践学习
基于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 Redis
深度解析Redis的缓存双写一致性
【4月更文挑战第20天】
10 1
|
2天前
|
存储 缓存 NoSQL
Redis入门到通关之Redis缓存数据实战
Redis入门到通关之Redis缓存数据实战
|
4天前
|
存储 缓存 运维
软件体系结构 - 缓存技术(5)Redis Cluster
【4月更文挑战第20天】软件体系结构 - 缓存技术(5)Redis Cluster
136 10
|
11天前
|
缓存 NoSQL Java
使用Redis进行Java缓存策略设计
【4月更文挑战第16天】在高并发Java应用中,Redis作为缓存中间件提升性能。本文探讨如何使用Redis设计缓存策略。Redis是开源内存数据结构存储系统,支持多种数据结构。Java中常用Redis客户端有Jedis和Lettuce。缓存设计遵循一致性、失效、雪崩、穿透和预热原则。常见缓存模式包括Cache-Aside、Read-Through、Write-Through和Write-Behind。示例展示了使用Jedis实现Cache-Aside模式。优化策略包括分布式锁、缓存预热、随机过期时间、限流和降级,以应对缓存挑战。
|
19天前
|
存储 缓存 NoSQL
使用redis进行缓存加速
使用redis进行缓存加速
27 0
|
20天前
|
存储 缓存 NoSQL
Java手撸一个缓存类似Redis
`LocalExpiringCache`是Java实现的一个本地缓存类,使用ConcurrentHashMap存储键值对,并通过ScheduledExecutorService定时清理过期的缓存项。类中包含`put`、`get`、`remove`等方法操作缓存,并有`clearCache`方法来清除过期的缓存条目。初始化时,会注册一个定时任务,每500毫秒检查并清理一次过期缓存。单例模式确保了类的唯一实例。
16 0
|
1月前
|
缓存 NoSQL Java
spring cache整合redis实现springboot项目中的缓存功能
spring cache整合redis实现springboot项目中的缓存功能
46 1
|
1月前
|
存储 缓存 NoSQL
[Redis]——缓存击穿和缓存穿透及解决方案(图解+代码+解释)
[Redis]——缓存击穿和缓存穿透及解决方案(图解+代码+解释)
269 0
|
1月前
|
缓存 NoSQL 数据库
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
|
1月前
|
缓存 NoSQL 安全
【Redis】缓存穿透
【Redis】缓存穿透
30 0

热门文章

最新文章