赞
踩
缓存就是数据交换的缓冲区(Cache),是存贮数据的临时地方,一般读写性能较高。
作用:
降低后端负载
提高读写效率,降低相应时间
成本:
数据一致性成本
代码维护成本
运维成本
内存淘汰 | 超时剔除 | 主动更新 | |
---|---|---|---|
说明 | 不用自己维护,利用redis的内存淘汰机制,当内存不足时自动淘汰部分数据。下次 查询时更新缓存 | 给缓存数据添加TTL时间,到期后自动删除缓存,下次查询时更新缓存 | 编写业务 逻辑,在修改数据库的同时,更新缓存 |
一致性 | 差 | 一般 | 好 |
维护成本 | 无 | 低 | 高 |
应用场景:
低一致性需求:使用redis自带的内存淘汰策略
高一致性需求:主动更新,并以超时剔除作为 兜底方案
读操作:
缓存命中直接返回
缓存未命中则查询数据库,并写入缓存,设定超时时间
写操作
先写数据库,然后再删除缓存
要确保数据库于缓存操作的原子性
缓存穿透是指客户端请求的 数据在缓存中和数据库中都不存在,这样缓存永远不会生效,这些请求都会打在数据库。
常见解决方案:
缓存空对象:
优点:实现简单,维护方便
缺点:
额外的内存消耗
可能造成短期的不一致
布隆过滤
优点:内存占用较少,没有多余key
缺点:
实现复杂
存在误判可能
指在同一时段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大的压力
解决方案:
给不同的key的ttl添加随机值
利用redis集群提高服务的可用性
给缓存业务添加降级限流策略
给业务添加多级缓存
缓存击穿问题也叫热点key问题,就是一个被高并发访问并且缓存重建业务叫复杂的key突然失效,无数的请求访问会在瞬间给数据库带来巨大的冲击
解决方案:
互斥锁
优点:
没有额外的内存消耗
保证一致性
实现简单
缺点:
线程需要等待,性能受影响
可能有死锁风险
逻辑过期
优点:线程无需等待,性能较好
缺点:
不保证一致性
有额外内存消耗
实现复杂
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。