Redis作为目前使用最广泛的缓存,相信大家都不陌生。但是使用缓存并没有这么简单,还要考虑缓存雪崩,缓存击穿,缓存穿透的问题,什么是缓存雪崩,击穿,穿透呢,出现这些问题又怎么解决呢,接下来学习一下吧。
数据穿透
Tips:Redis和数据库均无所要查询数据
当 Redis 和数据库中都没有我们想要的数据时,就需要考虑缓存穿透的问题了。
一般情况下我们会先去 Redis 中查找某资源,Redis 中查不到就去数据库中查,如果在数据库中依然不存在该数据,那么有可能会有人使用大量该数据查询请求攻击数据库,容易造成数据库宕机,这些请求像“穿透”了缓存一样直接打在数据库上,这种现象就叫做缓存穿透。

解决方法
1、缓存空结果
如果系统发现 Redis 及 DB 中都不存在该资源,就缓存空结果一段时间。需要注意哈,这次的失效时间不能设置的太长,否则数据的实效性会产生很大的问题。
2、用户合法性校验
对用户的请求合法性进行校验,拦截恶意重复请求。
3、布隆过滤器
看到这个名词不要慌。简单来说布隆过滤器的用途就是帮助你判断某个值是否存在。举个例子来看下:假设我们现在有一个长度为 9 的 bit 数组,该数组的每个位置上只能保存 1 或者 0,1 标识该位置被占用,

Redis缓存面临的问题包括数据穿透、数据击穿和数据雪崩。数据穿透是指请求的数据在Redis和数据库都不存在,可能导致数据库被攻击。解决方法包括缓存空结果、用户合法性校验和使用布隆过滤器。数据击穿是热点key过期导致大量请求直接到达数据库,可以通过设置热点数据永不过期或使用互斥锁来缓解。数据雪崩则是大量key同时失效,解决方案包括设置随机失效时间、热点数据均匀分布以及取消热点数据的过期时间。
最低0.47元/天 解锁文章
2187

被折叠的 条评论
为什么被折叠?



