redis实战(缓存)

缓存

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

作用:降低后端负载、提高读写效率,降低响应时间

成本:数据一致性成本、代码维护成本、运维成本

string类型也可以存List对象数组,将list转化为json,拿的时候可以直接转换为list

缓存更新策略

内存淘汰 超时剔除 主动更新
说明 Redis内存淘汰机制(不用自己维护) 到期自动删除缓存 修改数据库时更新缓存
一致性 一般
维护成本

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

高一致性需求:主动更新,超时剔除作为兜底方案,例如店铺详情的缓存

主动更新策略:cache aside pattern:由缓存调用者,在更新数据库的同时更新缓存

  1. 删缓存
  2. 单体系统:将缓存与数据库操作放在一个事务
  3. 分布式系统:利用TCC等分布式事务方案
  4. 先操作数据库,再删缓存

缓存穿透

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

解决

  1. 缓存空对象:
    • 优点:实现简单,维护方便
    • 缺点:额外内存消耗,可能造成短期的不一致
  2. 布隆过滤
    • 优点:内存占用少,没有多余key
    • 缺点:实现复杂、存在误判可能

主动策略:增强id复杂度,避免被猜测id规律

缓存雪崩

指在同一时段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。

解决方案:

  • 给不同的key的TTL添加随机值
  • 利用redis集群提高服务的可用性
  • 给缓存业务添加降级限流策略
  • 给业务添加多级缓存

缓存击穿

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

解决:

  • 互斥锁:一次只能一个线程访问数据库写缓存
    • 优点:没有额外内存消耗、保证一致性、实现简单
    • 缺点:线程需要等待,性能受影响;可能有死锁风险
  • 逻辑过期:缓存不删除,更新缓存期间继续用旧缓存
    • 优点:线程无需等待,性能较好
    • 缺点:不保证一致性,有额外内存消耗,实现复杂
相关推荐
倒流时光三十年26 分钟前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
forestsea33 分钟前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析
redis·缓存·redisson
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
佛祖让我来巡山1 小时前
Redis 为什么这么快?——「极速快递站」的故事
redis·redis为什么快?
怣501 小时前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx1 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星1 小时前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐2 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly2 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强