摘要:在某些查询中,可以将所有可能的查询条件放入这个集合,在查询之前使用这个集合对查询条件进行过滤,就可以避免缓存穿透的问题。解决方案二级缓存对于那些热度高的数据设置二级缓存,并且错开和一级缓存的失效时间,使请求不会同时穿透两层缓存去访问数据库
在我们的实际开发应用中,缓存机制的广泛存在,大大的提高了系统对数据库的请求承受阈值,但是在一些特定的场景下,需要去了解它可能出现的问题和对应的解决方案,才能更好的增加我们系统的健壮性
1.缓存穿透
问题场景
在一般的查询场景下,当一次查询从缓存中查询不到对应的信息,那么会继续去访问数据库进行查询,这种过程被称为缓存穿透。看似正常的操作,实际上,当有人恶意的去使用根本不存在的数据去频繁访问服务器,可能就会造成系统的瘫痪。
解决方案
bloom filter(布隆过滤器):是一种空间效率很高的随机数据结构,它利用位数组很简洁地表示一个集合,并能判断一个元素是否属于这个集合。它是一个判断元素是否存在集合的快速的概率算法。在某些查询中,可以将所有可能的查询条件放入这个集合,在查询之前使用这个集合对查询条件进行过滤,就可以避免缓存穿透的问题。
空值缓存:在第一次查询为空值之后,将这个查询条件key存入缓存中,缓存时间设置为较短时间,这样可以应对一些短时间内大量重复查询的情况。
2.缓存雪崩
问题场景
我们在使用例如Redis来进行缓存操作的时候,一般会给缓存设置一个过期时间,但是对于大量缓存过期时间相同的系统来说,可能会因为某个时间段缓存同时失效而造成所有本应该由缓存来接受的请求直接请求到数据库,造成数据库崩溃。当发生雪崩的时候,没有一片雪花觉得是自己的责任。
解决方案
交叉失效时间:在设置缓存时间的时候,我们可以在一段合理的范围时间内,随机的去设置这些缓存的过期时间,避免同一过期时间
3.缓存击穿
问题场景
缓存击穿是缓存雪崩的一个特例,某个多带带的热点的缓存因为过期时间导致失效,那么同样会有大量的请求去访问数据库导致崩溃。与缓存雪崩不同的是,缓存击穿更像是某一热度点的缓存雪崩。
解决方案
二级缓存:对于那些热度高的数据设置二级缓存,并且错开和一级缓存的失效时间,使请求不会同时穿透两层缓存去访问数据库
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/62113.html
摘要:并发设计的三大原则原子性原子性对共享变量的操作相对于其他线程是不可干扰的,即其他线程的执行只能在该原子操作完成后或开始前执行。发现两个线程运行结束后的值为。这就是在多线程情况下要求程序执行的顺序按照代码的先后顺序执行的原因之一。 并发设计的三大原则 原子性 原子性:对共享变量的操作相对于其他线程是不可干扰的,即其他线程的执行只能在该原子操作完成后或开始前执行。 通过一个小例子理解 pu...
摘要:进阶多线程开发关键技术后端掘金原创文章,转载请务必将下面这段话置于文章开头处保留超链接。关于中间件入门教程后端掘金前言中间件 Java 开发人员最常犯的 10 个错误 - 后端 - 掘金一 、把数组转成ArrayList 为了将数组转换为ArrayList,开发者经常... Java 9 中的 9 个新特性 - 后端 - 掘金Java 8 发布三年多之后,即将快到2017年7月下一个版...
摘要:边缘计算是指在网络边缘节点来处理分析数据。打好边缘战,三大运营商齐头并进为了加强自身在边缘计算领域的实力,三大运营商已经开始提前布局,并取得了一定的成绩。此外,据了解,目前中国联通边缘云生态合作伙伴已达家。随着万物互联时代的到来,网络边缘设备产生的数据量飞速增长,带来了更高的数据传输带宽需求,同时,新型应用也对数据处理的实时性以及数据存储也提出了更高的要求。传统的云计算模型不能满足现有的性能...
阅读 2468·2021-09-28 09:36
阅读 1455·2021-09-22 15:33
阅读 3586·2019-08-30 15:44
阅读 1723·2019-08-29 13:14
阅读 3112·2019-08-29 11:17
阅读 1419·2019-08-29 11:03
阅读 2887·2019-08-26 17:10
阅读 667·2019-08-26 12:13