在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
1. 简介如图所示,一个正常的请求 1.客户端请求张铁牛的博客。 2.服务首先会请求redis,查看请求的内容是否存在。 3.redis将请求结果返回给服务,如果返回的结果有数据则执行 4.服务从数据库中查询请求的数据。 5.数据库将查询的结果返回给服务。 6.如果数据库有返回数据,则将返回的结果添加到redis。 7.将请求到的数据返回给客户端。 2. 缓存穿透2.1描述通过接口访问一个缓存和数据库都不存在的数据。 因为服务出于容错考虑,当请求从持久层查不到数据则不写入缓存,这将导致请求这个不存在的数据每次都要到持久层去查询,失去了缓存的意义。 此时,缓存起不到保护后端持久层的意义,就像被穿透了一样。导致数据库存在被打挂的风险。 2.2 解决方案1.接口请求参数的校验。对请求的接口进行鉴权,数据合法性的校验等;比如查询的userId不能是负值或者包含非法字符等。 2.当数据库返回空值时,将空值缓存到redis,并设置合理的过期时间。 3.布隆过滤器。使用布隆过滤器存储所有可能访问的 key,不存在的 key 直接被过滤,存在的 key 则再进一步查询缓存和数据库。 3. 缓存击穿3.1 描述某个热点 key,在缓存过期的一瞬间,同时有大量的请求打进来,由于此时缓存过期了,所以请求最终都会走到数据库,造成瞬时数据库请求量大、压力骤增,导致数据库存在被打挂的风险。 3.2 解决方案1.加互斥锁。当热点key过期后,大量的请求涌入时,只有第一个请求能获取锁并阻塞,此时该请求查询数据库,并将查询结果写入redis后释放锁。后续的请求直接走缓存。 2.设置缓存不过期或者后台有线程一直给热点数据续期。 4. 缓存雪崩4.1 描述大量的热点数据过期时间相同,导致数据在同一时刻集体失效。造成瞬时数据库请求量大、压力骤增,引起雪崩,导致数据库存在被打挂的风险。 4.1 解决方案1.将热点数据的过期时间打散。给热点数据设置过期时间时加个随机值。 2.加互斥锁。当热点key过期后,大量的请求涌入时,只有第一个请求能获取锁并阻塞,此时该请求查询数据库,并将查询结果写入redis后释放锁。后续的请求直接走缓存。 3.设置缓存不过期或者后台有线程一直给热点数据续期。 5. 布隆过滤器5.1 描述布隆过滤器是防止缓存穿透的方案之一。布隆过滤器主要是解决大规模数据下不需要精确过滤的业务场景,如检查垃圾邮件地址,爬虫URL地址去重, 解决缓存穿透问题等。 布隆过滤器:在一个存在一定数量的集合中过滤一个对应的元素,判断该元素是否一定不在集合中或者可能在集合中。它的优点是空间效率和查询时间都比一般的算法要好的多,缺点是有一定的误识别率和删除困难。 5.2 数据结构布隆过滤器是基于 1.元素 2.元素 此时 当请求想通过布隆过滤器判断 5.3 “一定不在集合中”如图所示: 元素 也就是当判断不在 5.4 “可能在集合中”如图所示: 元素 这下就尴尬了,因为实际程序中并没有数据 5.5 ”删除困难“为什么布隆过滤器删除困难呢,如图所示: 如果删除了“tie”元素,
所以布隆过滤器数据删除困难,如果要删除的话,可以参考 5.6 为什么不使用HashMap呢?如果用HashSet或Hashmap存储的话,每一个用户ID都要存成int,占4个字节即32bit。而一个用户在bitmap中只需要1个bit,内存节省了32倍。 并且大数据量会产生大量的hash冲突,结果就是产生hash冲突的数据,仍然会进行遍历挨个比对(即使转成红黑树),这样对内存空间和查询效率的提升,仍然是有限的。 当然:数据量不大时,尽管使用。而且hashmap方便进行CRUD😂 到此这篇关于详解缓存穿透/击穿/雪崩原理及其解决方案的文章就介绍到这了,更多相关缓存穿透/击穿/雪崩内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论