缓存
定义:缓存就是数据交换的缓冲区,是存储数据的临时地方,一般读写性能较高
缓存的作用:
降低后端负载
提高读写效率,降低响应时间
缓存的成本:
数据库一致性成本
代码维护成本
运维成本
缓存更新策略:
业务场景:
低一致性需求:使用内存淘汰机制,例如店铺类型的查询缓存
高一致性需求:主动更新,并且以剔除方案兜底,例如店铺详情查询的缓存
主动更新策略
使用redis会产生的问题
1、缓存穿透:指客户端请求的数据在缓存中和数据库中都不存在,这样缓存永远不会生效,这些请求全都会到数据库。
解决方法:①缓存空对象 优点:实现简单,维护方便;缺点:额外的内存消耗,可能会导致到期的不一致 ②布隆过滤 优点:内存占用少,没有多余的key; 缺点:实现复杂,存在误判的可能;一般都用第一种解决缓存击穿问题
2、缓存雪崩:指同一时段大量的缓存同时失效或Redis服务宕机,导致大量请求到达数据库,带来很大的压力。
解决方法:①给不同的Key的TTL添加随机值 ②搭建Redis集群提高服务的可用性 ③给缓存业务添加降级限流策略 ④给业务添加多级缓存
2、缓存击穿:也叫热点key问题,就是一个被高并发访问并且缓存重建业务较复杂的key突然失效,无数的请求访问会在瞬时给数据库带来巨大的冲击。
解决方法:①互斥锁 优点:没有额外的内存消耗, 保证一致性,实现简单; 缺点:线程需要等待,性能会受到影响;可能会发生死锁 ②逻辑过期 优点:线程无需等待,性能较好; 缺点:不保证一致性,有额外的内存消耗,实现复杂