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

本文涉及的产品
云原生内存数据库 Tair,内存型 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
相关文章
|
2天前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
这篇文章介绍了如何在SpringBoot项目中整合Redis,并探讨了缓存穿透、缓存雪崩和缓存击穿的问题以及解决方法。文章还提供了解决缓存击穿问题的加锁示例代码,包括存在问题和问题解决后的版本,并指出了本地锁在分布式情况下的局限性,引出了分布式锁的概念。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
|
2天前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
这篇文章是关于如何在SpringBoot应用中整合Redis并处理分布式场景下的缓存问题,包括缓存穿透、缓存雪崩和缓存击穿。文章详细讨论了在分布式情况下如何添加分布式锁来解决缓存击穿问题,提供了加锁和解锁的实现过程,并展示了使用JMeter进行压力测试来验证锁机制有效性的方法。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解分布式情况下如何添加分布式锁 【续篇】
|
6天前
|
存储 缓存 NoSQL
基于SpringBoot+Redis解决缓存与数据库一致性、缓存穿透、缓存雪崩、缓存击穿问题
这篇文章讨论了在使用SpringBoot和Redis时如何解决缓存与数据库一致性问题、缓存穿透、缓存雪崩和缓存击穿问题,并提供了相应的解决策略和示例代码。
20 0
|
6天前
|
缓存 NoSQL Ubuntu
如何在 Ubuntu 14.04 上配置 Redis 缓存以加速 WordPress
如何在 Ubuntu 14.04 上配置 Redis 缓存以加速 WordPress
12 0
|
存储 缓存 NoSQL
Spring Boot2.5 实战 MongoDB 与高并发 Redis 缓存|学习笔记
快速学习 Spring Boot2.5 实战 MongoDB 与高并发 Redis 缓存
454 0
Spring Boot2.5 实战 MongoDB 与高并发 Redis 缓存|学习笔记
|
缓存 NoSQL 安全
6.0Spring Boot 2.0实战 Redis 分布式缓存6.0|学习笔记
快速学习6.0Spring Boot 2.0实战 Redis 分布式缓存6.0。
304 0
6.0Spring Boot 2.0实战 Redis 分布式缓存6.0|学习笔记
|
缓存 NoSQL Redis
首页数据显示-添加 redis 缓存(3)| 学习笔记
快速学习 首页数据显示-添加 redis 缓存(3)
132 0
首页数据显示-添加 redis 缓存(3)| 学习笔记
|
缓存 NoSQL Java
首页数据显示-添加 redis 缓存(1) | 学习笔记
快速学习 首页数据显示-添加 redis 缓存(1)
214 0
首页数据显示-添加 redis 缓存(1) | 学习笔记
|
存储 缓存 NoSQL
Redis 缓存|学习笔记
快速学习Redis 缓存
97 0
|
缓存 监控 NoSQL
Redis 缓存(学习笔记十一)
mysql+redis 优化 redis的监控平台:CacheCloud
715 0