Java面试八股之使用Redis会有哪些问题?击穿、穿透、雪崩等

  1. 使用Redis会有哪些问题?击穿、穿透、雪崩等

击穿:热点数据过期,大量并发请求被发送到数据库。

解决:设置热点数据永不过期,后台更新;增加互斥锁机制,第一个请求发现缓存失效后,从数据库获取,并更新缓存,后续请求继续从缓存中读取最新数据。

穿透:注意这个透字,顾名思义就是redis和数据库中都没有找到请求的数据,一般是非法请求或者尝试获取数据库中不存在的数据。

解决:缓存null值,防止出现请求穿透。增加请求验证,避免非法请求发送到Redis和数据库。布隆过滤器

雪崩:大量key同时过期失效,大量请求被发送到数据库。通常是因为大量key的过期时间设置成相同时间,或者Redis服务器宕机。

解决:部署哨兵模式或集群模式,防止服务宕机。设置随机的过期时间,避免大量key同时过期。

如果大家需要视频版本的讲解,欢迎关注我的B站:

相关推荐
Charles_go9 分钟前
C#中级48、Debug版本和Release版本有什么区别
java·linux·c#
u***276129 分钟前
Spring Boot 条件注解:@ConditionalOnProperty 完全解析
java·spring boot·后端
222you43 分钟前
MyBatis-Plus当中BaseMapper接口的增删查改操作
java·开发语言·mybatis
此生只爱蛋1 小时前
【Redis】服务端高并发分布式结构演进之路
数据库·redis·分布式
纪莫1 小时前
技术面:MySQL(一条SQL在MySQL的执行过程?、MyISAM和InnoDB的区别?数据库事务机制?)
java·数据库·java面试⑧股
闲人编程1 小时前
Python协程的演进:从yield到async/await的完整历史
java·前端·python·async·yield·await·codecapsule
q***92512 小时前
PHP操作redis
开发语言·redis·php
帅中的小灰灰2 小时前
C++编程建造器设计模式
java·c++·设计模式
动感小麦兜2 小时前
应用-常用工具部署命令
java·开发语言
日日行不惧千万里2 小时前
IDEA 是用什么开发的?
java·ide·intellij-idea