
课程咨询: 400-996-5531
投诉建议: 400-111-8989
认真做教育 专心促就业
我们在前几期的文章中给大家简单介绍了程序员在学习Java编程开发技术的时候需要注意的一些缓存问题等内容,而本文我们就通过案例分析再来了解一下,缓存击穿与缓存穿透解决方案。
一、缓存击穿
缓存击穿是指,针对某个访问缓存非常频繁,无法在缓存中处理,访问该数据的请求一下子都请求数据库,导致数据库压力倍增。
方案一:不设置过期时间
对于访问特别频繁的热点数据,就不设置过期时间
方案二:使用互斥锁
如果缓存失效,只有拿到锁才能访问数据库,降低数据库并发访问。
缓存雪崩和缓存击穿的差别在于雪崩是大量的缓存,击穿是单一的缓存。
缓存穿透
缓存穿透是指访问的数据既不在redis缓存中,也不在数据库中,因为数据库也不存在数据,也无法将数据库数据写入缓存中,每次请求都要请求缓存和服务器。不过这样也导致系统性能下降。
缓存穿透会发生如下两种情况:
误操作,删除了缓存和数据的数据。
恶意攻击:专门访问数据库中不存在的数据。
二、缓存穿透
方案一:缓存空值或缺省值
发生缓存穿透,在redis中缓存一个空值或者实现预选设置好的值(比如0),后续请求查询直接在redis中读取空值或者缺省值。
方案二:使用布隆过滤器
布隆过滤器由一个初值都为0的bit数组和N个哈希函数组成,可以用来快速判断某个数据是否存在。当数据写入数据库时,布隆过滤器会通过三个操作完成标记:
使用N个hash函数,分别计算这个数据的hash值,得到N个hash值。
把这N个hash值对bit数组的长度取模,得到每个hash值在数组中对位置。
把对应位置设置为1。如果数据不存在,那么就没用使用布隆过滤器标记过数据,那么,bit数组对应的bit位为零。只要bit数组有一个不为1,就表明布隆过滤器就没标记过该数据。
把数据写入数据库时,使用布隆过滤器做标记
当缓存消失后,在去数据库查询之前,通过查询布隆过滤器判断数据是否存在,如果不存在,就不查询数据库。
还有在请求入库添加检测,把恶意请求(参数不合理、参数非法、参数不存在或者id小于0)直接过滤掉。
【免责声明】:本内容转载于网络,转载目的在于传递信息。文章内容为作者个人意见,本平台对文中陈述、观点保持中立,不对所包含内容的准确性、可靠性与完整性提供形式地保证。请读者仅作参考。更多内容请加抖音达内三江区域学习了解。