Redis 缓存问题及解决
更新时间:2024年07月01日 11:59:38 作者:重庆大傑
网上收集的一些经典特效,这里因为篇幅较长,不加整理了,想运行的代码的朋友可以点击textarea中,全选复制即可。
一,缓存穿透(key在数据库不存在)
解决:
对请求过滤:参数检查、黑名单、白名单等,直接拒绝。
缓存空值:对查询不存在的数据也缓存下来(值为null),并设置较短过期时间。
使用布隆过滤器快速判断数据是否存在,避免通过查询数据库来判断(使用bitmaps实现):在写入数据库数据时,使用布隆过滤器做个标记,然后在用户请求发现缓存没有值时,查询布隆过滤器快速判断数据是否存在。
二,缓存击穿(热点key过期)
对于热点数据,当缓存失效的一瞬间,所有的请求都被下放到数据库去请求更新缓存,数据库被压垮。
解决:
访问数据库加分布式锁:获得锁的那个线程才能去访问数据库,并写回缓存,其他线程等待。
热点数据不过期:由后台异步更新缓存,或者在热点数据即将过期前,提前通知后台线程更新缓存以及重新设置过期时间。
三,缓存雪崩(大量key同时过期)
当大量缓存在同一时间过期,如果此时有大量的用户请求,瞬间所有的请求都被下放到数据库,数据库就崩掉了。
解决:
将缓存失效时间随机打散 : 在原有的失效时间基础上增加一个随机值(比如1到10分钟)这样每个缓存的过期时间都不重复了,也就降低了缓存集体失效的概率。
缓存设置为不过期 : 通过后台服务来更新缓存数据。
相关文章
为Redis设置密码的三种方法
Redis 是一个高性能的键值对数据库,广泛应用于缓存、消息队列等场景,为了保障 Redis 服务的安全性,设置密码认证是非常重要的一步,所以本文给大家介绍了为Redis设置密码的三种方法,需要的朋友可以参考下
2024-11-11
Windows中redis设置密码的两种方法
之前写的一个项目,有项目代码,有数据库,但是本地没redis,没法跑此项目,故思考在本地安装一个redis做登录session存储,所以开始动手实践,下面这篇文章主要给大家介绍了关于Windows中redis设置密码的两种方法,需要的朋友可以参考下
2023-04-04
Redis中切片集群详解
切片集群Redis中,数据增多了,是该加内存还是加实例?采用云主机来运行Redis实例,那么,该如何选择云主机的内存容量呢?用Redis保存5000万个键值对,每个键值对大约是512B方案一:大内存云主机:选择一台32GB内存的云主机来部署Redis
2025-01-01
在K8s上部署Redis集群的方法步骤
这篇文章主要介绍了在K8s上部署Redis集群的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2021-04-04
Redis持久化解读
Redis是一种内存级数据库,提供高速读写性能,但数据易失,它支持三种持久化方式:RDB(快照持久化)、AOF(追加文件持久化)和混合持久化,RDB通过快照将数据保存到磁盘,AOF记录所有写操作命令,混合持久化结合两者优点
2025-01-01
启动redis出现闪退情况的解决办法
最近使用Redis遇到启动闪退的问题,查阅资料后在一位大神的文章中找到了答案,这篇文章主要给大家介绍了关于启动redis出现闪退情况的解决办法,需要的朋友可以参考下
2023-11-11
最新评论