缓存更新策略

redis的缓存更新策略:

  • 先删除缓存,在更新数据库,缺点:当线程1进行一个更新的操作,先进行缓存删除,在修改数据库,但是修改数据库之前,线程2 进行查询缓存的操作,未命中,查找数据库,写入缓存,线程1修改完成后,但是此时缓存中的数据还是旧数据,会出现数据不一致问题,只有等这个缓存过期,下次查询时,才会获取正确的信息.
  • 先操作数据库,在删除缓存,这个方法显然比上一个更优

缓存更新策略的最佳实践方案:

1,低一致性需求:使用Redis自带的内存淘汰机制

  1. 高一致性需求:主动更新,并以超时剔除作为兜底方案
  • 读操作: 缓存命中则直接返回 缓存未命中则查询数据库,并写入缓存,设定超时时间
  • 写操作: 先写数据库,然后再删除缓存 要确保数据库与缓存操作的原子性
相关推荐
-Da-4 小时前
【操作系统学习日记】《现代处理器性能的三重奏:ISA架构、流水线与缓存系统》
后端·缓存·架构·系统架构
翻斗包菜7 小时前
Nginx 四大核心功能实战:正向代理 + 反向代理 + 缓存 + Rewrite 正则
运维·nginx·缓存
银河麒麟操作系统7 小时前
银河麒麟服务器操作系统IO机制详解
数据库·redis·缓存
番茄去哪了9 小时前
高并发选课系统页面阻塞现象的技术原理分析:同步交互与悲观锁机制
java·缓存·科普·面向对象编程
敲代码的嘎仔10 小时前
Java后端开发——Redis面试题汇总
java·开发语言·redis·学习·缓存·面试·职场和发展
y = xⁿ11 小时前
【黑马店铺二刷day02】将店铺查询信息添加到Redis中的业务操作
数据库·redis·缓存
一瓢西湖水12 小时前
探究Redis + Caffeine两级缓存架构
redis·缓存·架构
DisonTangor12 小时前
黑森林研究所提出KV缓存方式让生图模型能更好地多参考编辑
人工智能·缓存·ai作画·开源·aigc
Mr.朱鹏13 小时前
分布式-redis集群架构
java·redis·分布式·后端·spring·缓存·架构
Volunteer Technology13 小时前
Redis跟HashMap在结构上的区别
数据库·redis·缓存