Redis缓存

缓存

定义:缓存就是数据交换的缓冲区,是存储数据的临时地方,一般读写性能较高

缓存的作用:

降低后端负载

提高读写效率,降低响应时间

缓存的成本:

数据库一致性成本

代码维护成本

运维成本

缓存更新策略:

 业务场景:

低一致性需求:使用内存淘汰机制,例如店铺类型的查询缓存

高一致性需求:主动更新,并且以剔除方案兜底,例如店铺详情查询的缓存

主动更新策略

使用redis会产生的问题

1、缓存穿透:指客户端请求的数据在缓存中和数据库中都不存在,这样缓存永远不会生效,这些请求全都会到数据库。

解决方法:①缓存空对象  优点:实现简单,维护方便;缺点:额外的内存消耗,可能会导致到期的不一致  ②布隆过滤  优点:内存占用少,没有多余的key; 缺点:实现复杂,存在误判的可能;一般都用第一种解决缓存击穿问题

2、缓存雪崩:指同一时段大量的缓存同时失效或Redis服务宕机,导致大量请求到达数据库,带来很大的压力。

解决方法:①给不同的Key的TTL添加随机值  ②搭建Redis集群提高服务的可用性  ③给缓存业务添加降级限流策略   ④给业务添加多级缓存

2、缓存击穿:也叫热点key问题,就是一个被高并发访问并且缓存重建业务较复杂的key突然失效,无数的请求访问会在瞬时给数据库带来巨大的冲击。

解决方法:①互斥锁  优点:没有额外的内存消耗, 保证一致性,实现简单; 缺点:线程需要等待,性能会受到影响;可能会发生死锁  ②逻辑过期   优点:线程无需等待,性能较好; 缺点:不保证一致性,有额外的内存消耗,实现复杂

 

  

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值