详解Redis干系缓存问题
https://i-blog.csdnimg.cn/blog_migrate/2ede2a2f097b729611794d5299f2e23b.gif目录
缓存更新战略
定期⽣成
及时⽣成
缓存淘汰战略
Redis内置缓存淘汰战略
缓存预热
缓存穿透
缓存雪崩
缓存击穿
缓存更新战略
定期⽣成
每隔⼀定的周期(⽐如⼀天/⼀周/⼀个⽉), 对于访问的数据频次进⾏统计. 挑选出访问频次最⾼的前 %N的数据.
及时⽣成
先给缓存设定容量上限(可以通过 Redis 配置⽂件的 maxmemory 参数设定).
接下来把⽤⼾每次查询:
• 如果在 Redis 查到了, 就直接返回.
• 如果 Redis 中不存在, 就从数据库查, 把查到的效果同时也写⼊ Redis.
如果缓存已经满了(到达上限), 就触发缓存淘汰战略, 把⼀些 "相对不那么热⻔" 的数据淘汰掉.
按照上述过程, 持续⼀段时间之后 Redis 内部的数据⾃然就是 "热⻔数据" 了.
缓存淘汰战略
FIFO (First In First Out) 先辈先出
把缓存中存在时间最久的 (也就是先来的数据) 淘汰掉.
LRU (Least Recently Used) 淘汰最久未使⽤的
记载每个 key 的最近访问时间. 把最近访问时间最⽼的 key 淘汰掉.
LFU (Least Frequently Used) 淘汰访问次数最少的
记载每个 key 最近⼀段时间的访问次数. 把访问次数最少的淘汰掉.
Random 随机淘汰
从所有的 key 中抽取荣幸⼉被随机淘汰掉.
Redis内置缓存淘汰战略
Redis 内置的淘汰战略如下:
• volatile-lru 当内存不⾜以容纳新写⼊数据时,从设置了逾期时间的key中使⽤LRU(最近最
少使⽤)算法进⾏淘汰
• allkeys-lru 当内存不⾜以容纳新写⼊数据时,从所有key中使⽤LRU(最近最少使⽤)算法进⾏淘汰.
• volatile-lfu 4.0版本新增,当内存不⾜以容纳新写⼊数据时,在逾期的key中,使⽤LFU算法
进⾏删除key.
• allkeys-lfu 4.0版本新增,当内存不⾜以容纳新写⼊数据时,从所有key中使⽤LFU算法进⾏
淘汰.
• volatile-random 当内存不⾜以容纳新写⼊数据时,从设置了逾期时间的key中,随机淘汰数
据.
• allkeys-random 当内存不⾜以容纳新写⼊数据时,从所有key中随机淘汰数据.
• volatile-ttl 在设置了逾期时间的key中,根据逾期时间进⾏淘汰,越早逾期的优先被淘汰.
(相当于 FIFO, 只不外是局限于逾期的 key)
• noeviction 默认战略,当内存不⾜以容纳新写⼊数据时,新写⼊操作会报错.
缓存预热
界说
缓存预热是指在体系启动之前或体系到达高峰期之前,通过预先将常用数据加载到缓存中,以提高缓存掷中率和体系性能的过程。
目的
尽大概地避免缓存击穿和缓存雪崩。
减轻后端存储体系的负载,提高体系的响应速度和吞吐量。
减少冷启动影响,即体系重启或新启动时,避免首次请求处理缓慢。
提高数据访问速度,确保数据快速可用。
平滑流量峰值,帮助体系更好地处理高流量。
保证数据的时效性,特别是对于高度依靠于及时数据的体系。
预热方法
体系启动时加载:在体系启动时,将常用的数据加载到缓存中。
定时任务加载:定时执行任务,将常用的数据加载到缓存中,以保持数据的及时性和准确性。
手动触发加载:在体系到达高峰期之前,手动触发加载常用数据到缓存中。
用时加载:在用户请求到来时,根据用户的访问模式和业务需求,动态地将数据加载到缓存中。
缓存加载器:一些缓存框架提供了缓存加载器的机制,可以在缓存中不存在数据时,自动调用加载器加载数据到缓存中。
缓存穿透
界说
缓存穿透是指查询一个一定不存在的数据,由于缓存是不掷中时须要从数据库查询,查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到数据库去查询,进而给数据库带来压力。
产生原因
恶意攻击:攻击者故意查询不存在的数据,以此来消耗体系资源。
频仍查询不存在的数据:体系中的业务逻辑错误或计划不合理,导致频仍查询不存在的数据。
办理方案
对查询效果为null的数据进行缓存,设定短时限,例如30~60秒,最高5分钟,并定期进行整理。
利用布隆过滤器,通过哈希思想快速判定一个数据是否存在于集合中,从而避免无效的查询。
对URL中的key id值进行对称加密,防止黑客攻击。
缓存雪崩
界说
缓存雪崩是指缓存中数据大批量到逾期时间,而查询数据量巨大,引起数据库压力过大甚至宕机。
产生原因
Redis宕机。
采用了雷同的逾期时间,导致大量缓存同时失效。
办理方案
给不同的Key的TTL(Time To Live)添加随机值,避免大量缓存同时失效。
利用Redis集群提高服务的可用性。
给缓存业务添加降级限流战略。
给业务添加多级缓存。
缓存击穿
界说
缓存击穿是指一个热点的Key,有大并发集中对其进行访问,突然间这个Key失效了,导致大并发全部打在数据库上,导致数据库压力剧增。
产生原因
某个热点的key失效了,此时有大量请求同时访问该数据。
并发查询:多个请求同时查询一个数据,导致缓存未掷中,请求直接访问数据库。
办理方案
利用互斥锁:当缓存数据为空时,利用互斥锁保证只有一个线程可以访问数据库,其他线程等待该线程查询数据库并将效果写入缓存。
利用布隆过滤器快速判定一个key是否存在于缓存中,从而避免无效的查询。
预加载:在缓存中设置短暂的逾期时间,当缓存数据即将逾期时,提前异步更新缓存。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]