一篇文章搞清楚Redis 缓存预热,缓存击穿,缓存雪崩,缓存穿透。

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 一篇文章搞清楚Redis 缓存预热,缓存击穿,缓存雪崩,缓存穿透。

前言

我们一般的系统,在达到一定QPS之后,都会启用缓存来抗压。而大部分缓存解决方案都是用的redis。
Redis具有简单,稳定,数据可持久化等特点。得到了很多公司的实际应用。
使用Redis 在达到一定的业务场景的时候,就会出现我们经常在面试中遇到的关于缓存的几个问题。
缓存预热,缓存穿透,缓存击穿,缓存雪崩


一、缓存预热

直面意思上来说,以APP作为例子。就是在用户还没打开我们APP之前。就已经把数据库里面的热点数据放入到缓存中了。这样用户在进入APP的时候,请求的是缓存的里面的记录。这样就极大的减少了对于数据库的压力。造成缓存击穿

实际场景: 我们有一款APP,每次准点会推送一些PUSH消息。这样很多用户在1分钟之内大量进入APP,导致并发量瞬间突增。如果所有的瞬时流量全部集中到数据库中,会导致系统整体压力非常大。所以这个时候在用户进去之前必须对首页的数据进行缓存预热。这样再大的压力也只会集中打到服务器和Redis上面。

总结:缓存预热就是提前给用户准备好饭菜。用户进系统不用等待(等待数据库查询),直接就能开吃

二、缓存穿透

假如我们认为缓存是一堵墙,然后墙后面是我们的数据库。我们在业务场景中,对于热点数据应该要做到所有的请求都打在这堵墙上,对于数据库尽量减少请求。缓存穿透的意思就是绕过了这堵墙,访问了在缓存中一定查询不到的数据,这样就会把所有的请求打到数据库,从而造成了数据库的压力。

实际场景:我们对于用户ID,针对每个用户ID,每请求一次会对用户信息生成一个缓存,缓存key值就是用户的ID值。但是当我们把用户ID换成-1进行请求,因为我们的用户ID肯定是会大于0的,所以如果有这样的请求,我们在缓存里面铁定查不到这条数据。就会把所有的请求打到数据里面,造成一次查询,增加数据库压力。

解决方案:针对数据库查询为空的数据,也进行缓存。缓存时间设置小点。或者设置边界值。上述场景 针对ID小于0的请求,直接报错,不让请求。

三、缓存击穿

假如我们认为缓存是一堵墙,然后墙后面是我们的数据库。击穿直面意思就是把墙的某一点打穿了。那这个点肯定是热点数据。由于这个key一直被大量请求。突然这个缓存失效了,一下子就会把大量的压力给到了数据库。造成系统崩溃。

实际场景:微博热搜就是这样的一个真实场景,随时随地都会有大量的请求在微博热搜上面。如果这个时候微博热搜缓存突然失效。这个时候所有压力都在数据库上面,就会造成数据库压力突增,系统崩溃。

解决方案:针对热点数据永不过期。热点数据只能我们去替换。让其永不过期。

四、缓存雪崩

假如我们认为缓存是一堵墙,然后墙后面是我们的数据库。然后每块砖是一个缓存key。假定用户每进行一次请求。我们会生成一次缓存。添一块砖。这样下次请求的压力也是在砖上。但由于我们缓存是有过期时间的。如果突然所有的砖在同一时刻全部崩塌。那这个时候一瞬间所有的请求又都会在数据库上面。造成数据库压力过大崩溃。

实际场景:在商品抢购,一波商品时间比较集中的放入缓存中,假设缓存设置一个小时,当过期时间到达后,这批商品会统一失效,而对于这批商品的访问查询,会直接落到数据库上,对于数据库而言,就会产生周期性的压力波峰,甚至会造成数据库宕掉。

**解决方案:
1 针对key值设置随机过期时间,避免key值集中某一时间批量失效。
2 redis灾备。防止使用中redis主机崩溃导致系统崩溃
3 服务降级 优先提供核心服务**

相关实践学习
基于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
相关文章
|
7天前
|
缓存 NoSQL 关系型数据库
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
本文详解缓存雪崩、缓存穿透、缓存并发及缓存预热等问题,提供高可用解决方案,帮助你在大厂面试和实际工作中应对这些常见并发场景。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
|
8天前
|
存储 缓存 NoSQL
【赵渝强老师】基于Redis的旁路缓存架构
本文介绍了引入缓存后的系统架构,通过缓存可以提升访问性能、降低网络拥堵、减轻服务负载和增强可扩展性。文中提供了相关图片和视频讲解,并讨论了数据库读写分离、分库分表等方法来减轻数据库压力。同时,文章也指出了缓存可能带来的复杂度增加、成本提高和数据一致性问题。
【赵渝强老师】基于Redis的旁路缓存架构
|
16天前
|
缓存 NoSQL Redis
Redis 缓存使用的实践
《Redis缓存最佳实践指南》涵盖缓存更新策略、缓存击穿防护、大key处理和性能优化。包括Cache Aside Pattern、Write Through、分布式锁、大key拆分和批量操作等技术,帮助你在项目中高效使用Redis缓存。
93 22
|
15天前
|
缓存 NoSQL 中间件
redis高并发缓存中间件总结!
本文档详细介绍了高并发缓存中间件Redis的原理、高级操作及其在电商架构中的应用。通过阿里云的角度,分析了Redis与架构的关系,并展示了无Redis和使用Redis缓存的架构图。文档还涵盖了Redis的基本特性、应用场景、安装部署步骤、配置文件详解、启动和关闭方法、systemctl管理脚本的生成以及日志警告处理等内容。适合初学者和有一定经验的技术人员参考学习。
105 7
|
20天前
|
存储 缓存 监控
利用 Redis 缓存特性避免缓存穿透的策略与方法
【10月更文挑战第23天】通过以上对利用 Redis 缓存特性避免缓存穿透的详细阐述,我们对这一策略有了更深入的理解。在实际应用中,我们需要根据具体情况灵活运用这些方法,并结合其他技术手段,共同保障系统的稳定和高效运行。同时,要不断关注 Redis 缓存特性的发展和变化,及时调整策略,以应对不断出现的新挑战。
53 10
|
20天前
|
缓存 监控 NoSQL
Redis 缓存穿透的检测方法与分析
【10月更文挑战第23天】通过以上对 Redis 缓存穿透检测方法的深入探讨,我们对如何及时发现和处理这一问题有了更全面的认识。在实际应用中,我们需要综合运用多种检测手段,并结合业务场景和实际情况进行分析,以确保能够准确、及时地检测到缓存穿透现象,并采取有效的措施加以解决。同时,要不断优化和改进检测方法,提高检测的准确性和效率,为系统的稳定运行提供有力保障。
48 5
|
20天前
|
缓存 监控 NoSQL
Redis 缓存穿透及其应对策略
【10月更文挑战第23天】通过以上对 Redis 缓存穿透的详细阐述,我们对这一问题有了更深入的理解。在实际应用中,我们需要根据具体情况综合运用多种方法来解决缓存穿透问题,以保障系统的稳定运行和高效性能。同时,要不断关注技术的发展和变化,及时调整策略,以应对不断出现的新挑战。
42 4
|
1月前
|
存储 缓存 NoSQL
数据的存储--Redis缓存存储(一)
数据的存储--Redis缓存存储(一)
|
1月前
|
存储 缓存 NoSQL
数据的存储--Redis缓存存储(二)
数据的存储--Redis缓存存储(二)
数据的存储--Redis缓存存储(二)
|
1月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
74 6