栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

redis缓存穿透

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

redis缓存穿透

redis缓存穿透

  1. 什么是缓存穿透?
    缓存穿透就是当用户请求的数据redis缓存中没有时 , 这个请求会落到数据库 , 当用户请求一个没有的数据时 , 如果有黑客用大量去请求数据库没有的数时 , 这些请求都会落到数据库上 , 会造成一个数据库的压力甚至瘫痪 .
  2. 解决方法:
    (1) 当请求到数据库中没有的数据是 , 也将这个请求添加到Redis缓存中去 , 将value设置成空就可以了 , 当用户请求再次到来的时候直接在redis中将空值返回给用户就可以了 . 就算以后数据拓展了, 以后有这样的一个真实数据了 , 真实的数据也会将这个空值给覆盖到的 .
    (2) 布隆过滤器: 迅速判断一个元素是否在一个集合中的 .
    布隆过滤器就是维护一个集合 , 当Redis中存进去一个key是 , 布隆过滤器就会在相应的位置上 , 用1进行标记 , 当用户请求的值在布隆过滤器上的标记是0的时候 , 就直接给用户请求进行返回 , 不会经过redis了 . 但是也会有误差 , 会有多个值存在集合的同一位置的情况 , 而且当数据库和Redis移除一个值的时候 , 布隆过滤器是不能进行移除的 . 会提高效率 , 但是也会增加代码的复杂度 , 如果进行Redis集群的时候每一个接点都要进行维护布隆过滤器 , 比较复杂了.

redis缓存雪崩

  1. 什么是缓存雪崩?
    当某一个时间点大面积的key过期实效了, 但是在这个时候又有好的用户请求同时过来 , 这么多的请求会同时落到数据库上面 , 造成一个数据库的压力 .

  2. 雪崩预防:
    (1) 永不过期
    (2) 过期时间错开
    (3) 多缓存结合
    (4) 采购第三方的redis

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/826648.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号