现分析Redis缓存使用过程失效的一些问题,在有缓存的情况下,查询数据的顺序是先查询缓存,如果查询到数据则直接返回数据,如果没有查询到数据,则到数据库中查询,数据库中有数据的话,将查询出的数据写到缓存并返给用户,写到缓存中的目的是以备下次查询时可以直接从缓存中获取信息,这本身是一个正常的查询过程,但是我们用redis的一个作用就是使用其缓存数据的作用,如果没有控制好其缓存设置,数据的查询可能就会出现一些问题,甚至影响系统的正常运行,现在总结redis缓存失效的三种情况及其对应的解决方法。

1、cache avalanche-缓存雪崩

缓存雪崩是指在一定时间内,缓存中大量的数据失效,导致大量的请求访问数据库,会给数据库产生很大的访问压力,导致CPU和内存过载,从而引起系统服务失败,这里有一个关键点,就是缓存中大量的数据甚至全部数据都不可用了,致使这种情况可能出现的原因有:

1)缓存服务器宕机了,甚至缓存集群都宕掉了

2)缓存服务器是好的,但是缓存中大量的数据在同一时期失效了

解决方案:

1)针对集群宕机,则需要部署高可用的redis集群服务,这是我们解决这一问题可以想到的办法,具体实现可以参考网友给出的一些方案,如https://blog.csdn.net/u014209205/article/details/82113258

2)缓存中大量的数据在同一时间失效了,这个很可能是因为在设置缓存有效时间时,将大量的数据的有效时间设置为一样导致的,比如所有数据的有效时间都设置为2分钟,如果并发量很高而且访问的数据又很多的话,可能有很多的数据的生效时间都是一样的,这样2分钟到了会有很多的数据失效,这时候大量的请求再来的时候会发现要查询的数据缓存中是不存在的, 则只能查询数据库,会在短时间内对数据库造成很大的访问压力,解决方法是可以为每个数据设置一个随机的有效时间,这样最起码不会导致大量的数据在同一时间失效

2、cache penetration-缓存穿透

缓存穿透是指反复高频查询那些根本不存在的数据(数据库中也不存在),根据查询数据的顺序,先缓存后查数据库,但是要查询的数据根本不存在,这时如果不实施相应的措施的话,会给数据库造成很大的访问压力,缓存也就失去了它存在的意义,针对这种问题,可以采用的解决方法是:

1)如果查询到的数据为空,也可以将这个空值存储到缓存中,缓存的有效时间设置的短一些

2)非法请求需要做认证拦截操作,接口层添加校验,如用户鉴权校验,id校验,id<=0的直接拦截

3)在查询redis缓存之前,使用布隆过滤器先进行查询,如果不存在则直接返回结果,详见https://zhuanlan.zhihu.com/p/348332384

3、cache breakdown-缓存击穿

缓存击穿是指,如果一个数据是一个热点数据,也就是有很多并发请求经常性地访问该数据,如果该数据在缓存中失效了,会导致大量的请求访问数据库,从而产生很大的查询压力,注意这里和雪崩还是有不同点的,那如何控制这些的热点数据以及访问这些热点数据的请求呢?可以直接想到的方案有:

1)不让热点数据失效,也就是将热点数据设置为永久有效的,热点数据的设置可参考:https://blog.csdn.net/fuqianming/article/details/99682764

2)对于访问热点数据的请求设置互斥锁,通过redis的setnx命令设置互斥锁

上面3点作为redis缓存失效问题的初探,深究起来其内容还是非常丰富的,但有时候感觉,像五柳先生之好读书而不求甚解其实有时候还是挺对的,现在的知识太多了,刚开始可以先了解一个概念,等用到的时候可以快速搜索出相关知识,再加以深度学习,这未尝不是一个学习的好办法......

初探redis缓存击穿、穿透、雪崩问题的更多相关文章

  1. Redis-缓存击穿/穿透/雪崩

    缓存击穿/穿透/雪崩 Intro 使用缓存需要了解几个缓存问题,缓存击穿.缓存穿透以及缓存雪崩,需要了解它们产生的原因以及怎么避免,尤其是当你打算设计自己的缓存框架的时候需要考虑如何处理这些问题. 缓 ...

  2. Redis缓存击穿、缓存穿透、缓存雪崩

    文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. 上篇文章谈到了Redis分布式锁,实际上就是为了解释为什么做缓存采用Redis而不使用map/guava.缓存 ...

  3. Redis 缓存击穿(失效)、缓存穿透、缓存雪崩怎么解决?

    原始数据存储在 DB 中(如 MySQL.Hbase 等),但 DB 的读写性能低.延迟高. 比如 MySQL 在 4 核 8G 上的 TPS = 5000,QPS = 10000 左右,读写平均耗时 ...

  4. REDIS 缓存的穿透,雪崩和热点key

    穿透 穿透:频繁查询一个不存在的数据,由于缓存不命中,每次都要查询持久层.从而失去缓存的意义. 解决办法:①用一个bitmap和n个hash函数做布隆过滤器过滤没有在缓存的键.   ②持久层查询不到就 ...

  5. 谈谈redis缓存击穿透和缓存击穿的区别,雪崩效应

    面试经历 在很长的一段时间里,我以为缓存击穿和缓存穿透是一个东西,直到最近去腾讯面试,面试官问我缓存击穿和穿透的区别:我回答它俩是一样的,面试官马上抬起头用他那细长的单眼皮眼睛瞪着我说:"你 ...

  6. redis缓存击穿和缓存雪崩

    工作中经常会用到redis来做缓存,以防止后台db挂掉.但是db数据一般都在10T以上,不可能把mysql中的数据全部放入redis中,所以一般是将一些热key放入redis中. 缓存击穿 一个请求先 ...

  7. redis 缓存击穿 看一篇成高手系列3

    什么是缓存击穿 在谈论缓存击穿之前,我们先来回忆下从缓存中加载数据的逻辑,如下图所示 因此,如果黑客每次故意查询一个在缓存内必然不存在的数据,导致每次请求都要去存储层去查询,这样缓存就失去了意义.如果 ...

  8. Redis缓存击穿

    缓存击穿 缓存击穿,是指一个key非常热点,在不停的扛着大并发,大并发集中对这一个点进行访问,当这个key在失效的瞬间,持续的大并发就穿破缓存,直接请求数据库,就像在一个屏障上凿开了一个洞. 比如在做 ...

  9. redis击穿,穿透,雪崩,分布式锁,api(jedis,luttuce)

    击穿:(redis做缓存用,肯定发生了高并发,到达数据库查询) 设置key 的过期时间,过期后没有这个key,找不到了,就穿过了(其中一个key过期导致并发访问数据库) LRU (LRU,即:最近最少 ...

  10. redis缓存击穿问题一种思路分享

    思路每一个key都有一个附属key1,附属key1可以是key加特定前缀组成,key对应value为真正的缓存数据,附属key1对应的value不重要,可以是随便一个值,附属key1的作用主要是维护缓 ...

随机推荐

  1. .NET Core 3.0 WebApi 使用Swagger

    1.安装指定版本: Swashbuckle.AspNetCore 5.0.0-rc4(目前稳定版本4.0.1在AspNetCore3.0中会报错误) 2.后台C#代码要严格格式必须加[HttpPost ...

  2. JavaScript垃圾回收机制的了解

    对于js种的任意长度字符串,对象,数组是没有固定大小的,只有在分配存储时,解释器就会分配内存来存储这些数据.当js的解释器消耗完系统所有可用内存时,就会造成系统崩溃.因此js有着自己的一套垃圾回收机制 ...

  3. Python_QT_量化投资/量化交易 基础入门课

    量化投资/量化交易 基础入门课 https://www.bilibili.com/video/BV1n4411q7ic?from=search&seid=1127232108574476398 ...

  4. js滚动加载数据

    话不多说,直接上代码,有些地方需要加自己的逻辑,自己加 <!DOCTYPE html><html><head lang="en"> <me ...

  5. OSI网络七层模型简明教程

    如果你读过计算机专业,或者学习过网络通信,那你一定听说过 OSI 模型,它曾无数次让你头大.OSI 是 Open System Interconnection 的缩写,译为"开放式系统互联& ...

  6. 替代学习物联网-云服务-04TLINK云MQTT

    1.注册TLINK www.tlink.io 记录下登录的用户名,密码.MQTT需要 2.添加设备  3.设备序列号:clientID 4.mqtt.fx调试器  5.订阅主题 在MQTT.fx上,单 ...

  7. 【2020NOI.AC省选模拟#5】C. 光滑序列

    题目链接 原题解: 光滑的序列一定有长度为$K$的循环节. 使用动态规划,设$F(i,j)$为使前$i$个整数的和为$j$的最小修改次数. 记$cost(i,v)$为令$A_i,A_{i+K},A_{ ...

  8. CCPC2021网络赛 1012 Remove

    2021CCPC网络赛 1012 Remove 题意 给定 \(n, m\),然后再给 \(m\) 个素数,问对于所有 \(i \in [1,n]\),将 \(i\) 操作至 \(0\) 的最小操作数 ...

  9. Spring-动力节点

    一.Spring启示录 阅读以下代码: package com.powernode.oa.controller; import com.powernode.oa.service.UserService ...

  10. linux虚拟机,ifconfig无法获取静态ip地址

    之前一直显示这种ip地址,如下图(网图),查看了DHCP,是正常启动的,虚拟网络编辑器中设置的也正确.后来发现更改虚拟机的设置后就可以了,如下: 设置方法:VMware-虚拟机-设置-网络适配器,选择 ...