Java最常见的面试题:什么是缓存穿透?解决方案?

参考:​什么是缓存雪崩、击穿、穿透? | 小林coding (xiaolincoding.com)

说说缓存穿透?

缓存穿透就是:当用户来请求数据的时候,发现缓存里面没有想要请求的数据,就奔向数据库,但是数据库也没有他们请求的这个数据,那么当有大量这样的请求到来时,数据库的压力骤增。

缓存穿透出现的原因:

业务误操作:缓存和数据库中的数据都被误删了,导致查询数据的时候缓存里和数据库里面没有该数据。

黑客恶意攻击:故意大量访问某些读取不存在数据的业务。 

解决缓存穿透的方案:

1 缓存空值或默认值:把不存在的这些数据设置为缓存空值或者默认值,这样用户来请求数据的时候请求到这个空值之后就走人,别去数据库里面请求了

2 使用布隆过滤器快速判断数据是否存在:避免通过查询数据库来判断数据是否存在。

3 非法请求的设置:在 API 入口处我们要判断求请求参数是否合理,请求参数是否含有非法值、请求字段是否存在,如果判断出是恶意请求就直接返回错误,避免进一步访问缓存和数据库。

布隆过滤器是怎么解决缓存穿透的?

布隆过滤器的作用就是:快速判断数据是否存在,避免通过查询数据库来判断数据是否存在。

怎么判断呢?

当我们在数据库里面写入数据的时候,每写入一个数据都要标记在布隆过滤器上,(使用布隆过滤器做个标记),当用户请求数据的时候,发现缓存里面没有这个数据,业务线程确认缓存失效后,就可以通过布隆过滤器查询有没有想要的那个数据,不存在就不用通过数据库查询数据是否存在,就不会造成缓存穿透了。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值