总结一下Redis的缓存雪崩、缓存击穿、缓存穿透
大家好,今天本人给大家带来文章《总结一下Redis的缓存雪崩、缓存击穿、缓存穿透》,文中内容主要涉及到Redis、缓存击穿、缓存穿透,如果你对数据库方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!
缓存击穿
缓存击穿指的是在高并发情况下,一个缓存的key在缓存中不存在,导致每次请求都要访问数据库,从而导致数据库压力过大,甚至崩溃。这种情况通常发生在一些热点数据上,比如用户登录信息等。
原因
缓存击穿的原因是因为在某些热点数据的key失效或者被删除时,大量的并发请求同时访问这个key,导致缓存中不存在这个key的数据,从而每个请求都需要去访问数据库获取数据,造成数据库压力过大。
解决方案
1.设置热点数据永不过期
在缓存中设置热点数据永不过期可以有效地避免缓存击穿问题。但是这种方式会导致缓存中存在很多过期但是占用内存的数据,因此需要在设置缓存数据时进行权衡。
String key = "hot_data";
String value = redis.get(key);
if (value == null) {
value = db.get(key);
if (value != null) {
redis.set(key, value);
redis.persist(key); //设置key永不过期
}
}
2.设置热点数据短期过期
为了避免缓存中过多占用内存的数据,可以将热点数据设置一个相对较短的过期时间,比如1分钟,这样可以避免过期数据占用过多内存。当热点数据过期后,可以在后台异步更新缓存数据。
String key = "hot_data";
String value = redis.get(key);
if (value == null) {
//添加分布式锁,避免缓存穿透
if(redis.setNx("lock_"+key,"value")){
value = db.get(key);
if (value != null) {
redis.set(key, value);
redis.expire(key,60); //设置key过期时间为1分钟
}
redis.del("lock_"+key);
}else {
Thread.sleep(50);
return queryDataFromCache(key);
}
}
缓存穿透
缓存穿透指的是当大量的并发请求同时查询一个不存在的key时,由于缓存中没有对应的数据,所以每个请求都会去访问数据库,导致数据库压力过大。
原因
缓存穿透的原因是由于黑客攻击或者恶意请求,可能会对某些不存在的数据进行大量的请求,从而导致缓存穿透问题。
解决方案
1.对查询结果为空的key设置空值
当缓存查询的结果为空时,可以将结果设置为空值写入缓存,这样下次查询相同的key时,可以直接从缓存中获取结果,避免了查询数据库的开销。
String key = "not_exist_data";
String value = redis.get(key);
if (value == null) {
//添加分布式锁,避免缓存穿透
if(redis.setNx("lock_"+key,"value")){
value = db.get(key);
if (value != null) {
redis.set(key, value);
}else {
redis.set(key, ""); //设置空值
redis.expire(key, 60); //设置过期时间为1分钟
}
redis.del("lock_"+key);
}else {
Thread.sleep(50);
return queryDataFromCache(key);
}
}
2.BloomFilter过滤非法请求
使用BloomFilter可以对请求参数进行过滤,将非法请求拦截在系统外部,从而避免了对系统的压力。
BloomFilter filter = new BloomFilter(10000, 0.001); //设置布隆过滤器
String key = "not_exist_data";
if(filter.mightContain(key)){
return null;
}
String value = redis.get(key);
if (value == null) {
//添加分布式锁,避免缓存穿透
if(redis.setNx("lock_"+key,"value")){
value = db.get(key);
if (value != null) {
redis.set(key, value);
}else {
filter.put(key); //将非法key加入过滤器
}
redis.del("lock_"+key);
}else {
Thread.sleep(50);
return queryDataFromCache(key);
}
}
缓存雪崩
缓存雪崩指的是在缓存中存在大量的key过期时间相同或者失效的情况下,当这些key同时失效时,大量的并发请求都会涌入数据库,导致数据库压力过大,甚至崩溃。
原因
缓存雪崩的原因是因为在缓存中存在大量的key同时过期,导致大量的并发请求同时涌入数据库。
解决方案
1.缓存数据随机过期时间 为了避免缓存中大量key同时过期,可以设置每个缓存数据的过期时间不同,比如可以在原有过期时间的基础上添加一个随机时间,这样可以避免大量key同时过期的情况。
String key = "hot_data";
String value = redis.get(key);
if (value == null) {
//添加分布式锁,避免缓存穿透
if(redis.set
2.缓存数据预加载 为了避免在缓存中大量的key失效,可以在缓存数据过期之前,提前将缓存数据刷新到缓存中,保证数据的可用性。
String key = "hot_data"; 3.限流降级 当缓存雪崩问题出现时,可以通过限流降级的方式来减少对数据库的请求,从而保证系统的可用性。可以通过配置Hystrix等限流降级框架来实现。 String key = "hot_data"; Redis的使用,可以有效地提高系统的性能和可用性。但是在使用过程中,需要注意缓存击穿、缓存穿透和缓存雪崩等问题,采用适当的解决方案来避免这些问题的发生,从而保证系统的稳定性和可靠性。 理论要掌握,实操不能落!以上关于《总结一下Redis的缓存雪崩、缓存击穿、缓存穿透》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
String value = redis.get(key);
if (value == null) {
//添加分布式锁,避免缓存穿透
if(redis.setNx("lock_"+key,"value")){
value = db.get(key);
if (value != null) {
redis.set(key, value);
redis.expire(key, 1800); //设置过期时间为30分钟
}
redis.del("lock_"+key);
}else {
Thread.sleep(50);
return queryDataFromCache(key);
}
}else {
//判断缓存是否需要刷新
if(redis.ttl(key) 300){
new Thread(() -> {
String newValue = db.get(key);
if (newValue != null) {
redis.set(key, newValue);
redis.expire(key, 1800); //设置过期时间为30分钟
}
}).start();
}
}
String value = redis.get(key);
if (value == null) {
//使用Hystrix进行限流降级
value = HystrixCommand.execute(() -> {
String data = db.get(key);
redis.set(key, data);
redis.expire(key, 1800); //设置过期时间为30分钟
return data;
}, () -> {
return "系统繁忙,请稍后重试!";
});
}总结

- 上一篇
- 修复:Windows 11 或 10 中的 Windows 应用商店错误 0x803fb005

- 下一篇
- Gmail和Docs正在使用人工智能工具来帮助你撰写职位描述
-
- 懦弱的火车
- 太全面了,收藏了,感谢大佬的这篇博文,我会继续支持!
- 2023-05-17 21:50:31
-
- 个性的小天鹅
- 赞 ??,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享技术贴!
- 2023-05-08 05:53:05
-
- 耍酷的八宝粥
- 这篇技术贴真是及时雨啊,up主加油!
- 2023-05-06 22:50:19
-
- 秀丽的大米
- 这篇文章内容太及时了,太细致了,写的不错,码起来,关注老哥了!希望老哥能多写数据库相关的文章。
- 2023-05-01 17:06:52
-
- 数据库 · Redis | 3小时前 |
- Redis与MongoDB缓存优化方法
- 193浏览 收藏
-
- 数据库 · Redis | 7小时前 |
- Redis安全配置更新操作教程
- 313浏览 收藏
-
- 数据库 · Redis | 19小时前 |
- Redis单节点迁移到集群的步骤详解
- 362浏览 收藏
-
- 数据库 · Redis | 20小时前 |
- Redis原子操作实现方式及使用场景
- 300浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis性能优化配置全攻略
- 173浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis性能问题分析及常见原因解析
- 234浏览 收藏
-
- 数据库 · Redis | 1天前 |
- 高并发Redis优化技巧分享
- 227浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis带宽瓶颈检测与优化方法
- 464浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis有序集合实现高效排行榜玩法
- 460浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis安全配置更新操作教程
- 146浏览 收藏
-
- 数据库 · Redis | 1天前 |
- 监控Redis集群健康的必备工具与指标
- 324浏览 收藏
-
- 数据库 · Redis | 2天前 |
- Redis带宽瓶颈检测与优化方法
- 337浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 95次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 104次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 98次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 96次使用
-
- 分享Redis高可用架构设计实践
- 2023-01-24 286浏览
-
- Go与Redis实现分布式互斥锁和红锁
- 2022-12-22 117浏览
-
- Redis的各项功能解决了哪些问题?
- 2023-02-18 185浏览
-
- Go+Redis实现延迟队列实操
- 2023-02-23 426浏览
-
- 分享 echo-framework 项目基础框架
- 2023-01-11 134浏览