为什么要使用缓存,什么是缓存雪崩、缓存穿透、缓存击穿

为什么要使用缓存     

        一般我们都是使用数据库来存储我们的数据的,但是数据库的读取速度是相对缓慢的而且还容易奔溃,这是因为数据库存储的数据都是存储在磁盘里的,而磁盘是计算机中读写速度是最慢的,因此当我们使用数据库来存储我们的数据时,若用户数量变得庞大,就会有大量的请求访问数据库,这时导致数据库压力会成倍增长,严重就会导致数据库崩溃。为解决这一问题我们通常会加入数据库缓存来解决这个问题,以Redis缓存为例,Redis缓存的是直接存储在内存中的,内存的读写速度比磁盘快好几个量级。我们加入Redis缓存后,会将我们从数据库中读取到的数据放到缓存中,当我们下次再想查询时就可以直接从缓存中读取,这样读取速度就会提升许多,而且数据库也不容易崩溃。

什么是缓存雪崩

        是指大量的缓存数据同时失效,或者Redis发生故障,导致大量的请求直接冲击数据库。我们称为缓存雪崩。

        根据问题的原因,我们会使用不一样的的办法,若是大量数据同时失效,我们可以设置不同的过期时间,一般我们都会给缓存设置一个过期的时间,在设置过期时间里加一个随机数,就可以避免大量请求同时访问数据库。或者使用双key策略,不同的key都缓存同一个value,一个设置过期时间,一个不设置过期时间当备用,当设置过期时间的key失效时,就直接访问不过期的key,缓存更新时同时更新两个key,这样也可以避免大量的请求直接访问数据库

若是Redis故障时,可以部署redis集群来应对,一个redis故障还有其他的redis在运作,这样也可以避免缓存雪崩。

什么是缓存击穿

        缓存击穿,是指热点数据缓存过期,导致大量的高并发数据直接访问数据库,可以认为是缓存雪崩的子集,一个大面积崩塌,一个单点击穿。

处理的方法也与缓存雪崩一致,目的都是防止大量请求访问数据库,还是用缓存雪崩的处理方法,对热点数据加互斥锁,不设置过期时间等。

什么是缓存穿透

        缓存穿透是指用户访问的数据既不在缓存中也不在数据库中,当有大量的这样的请求到来,会加大数据库的压力。

一般发生这种情况可能是:

        1.业务操作错误,误把数据库中的数据删除了,导致用户访问的数据库在数据库中不存在;

        2.黑客攻击,故意读取这些不存在的数据。

解决方法:

        1.使用布隆过滤器快速判断数据是否存在数据库中,避免使用数据库查询。

        2.非法数据处理,当发现非法访问时直接返回null

        

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值