当前位置: 首页 > news >正文

redis缓存更新策略

更新缓存策略:
对于低一致性需求的业务:使用redis自带的内存淘汰机制就行了,自动失效,等查询时再更新。
对于高一致性需求的业务:推荐主动更新,由缓存的调用者更新数据库的同时更新缓存(删除缓存)。
这里的一致性指的是缓存中的数据和数据库中的数据一致。

1.更新缓存还是删除缓存?
推荐删除缓存,因为如果数据库一直更新,缓存也随之更新,但是这期间根本没人来查数据,那这些更新都是无用的。直接删除缓存,等用户查询时,查询数据库的同时更新缓存更好。
2.如何保证缓存与数据库操作的同时成功或失败?
3.先删缓存再更新数据库还是先更新数据库再删缓存?
答:先更新数据库在删除缓存
先更新数据库,再删缓存的情况:
假设一开始缓存中没有数据,数据库中数据是10
线程1,查询数据库中的数据10,同时更新为缓存10。
线程2,更新数据库数据为20,同时删除缓存。
线程1查询到数据库中的数据10后,还没更新缓存,就切换到线程2,线程2更新数据库数据为20,同时删除缓存,这时切回线程1,更新缓存为10。这时数据库中数据为20,缓存数据为10出现了不一致的情况。
但这种发生几率很小,更新缓存是很快的操作,这时被切到线程2更新数据库数据几乎不太可能。
而且发生了这种事情我们也可以给缓存设置时间,从而弥补这种事情发生。

在这里插入图片描述

先删缓存,再更新数据库的情况:
这种方法不但会在上面哪种情景下发生数据不一致,在下面这种情景下也会发生数据不一致。
假设一开始缓存中的数据是10,数据库中数据是10
线程1,删除缓存,更新数据库数据为20
线程2,查询数据,同时更新缓存
线程1删除缓存后,这时切换到线程2,线程2去查询缓存,没有查到就去数据库中进行查询,
最终把数据库旧值10查询出来,同时把缓存更新为10,这时切回线程1,把数据库数据更新为20
最终数据库数据为20,缓存数据为10,数据不一致。
在这里插入图片描述

http://www.lryc.cn/news/312896.html

相关文章:

  • 【操作系统学习笔记】文件管理1.4
  • 快递包装展|2024上海国际电商物流包装产业展览会
  • vue页面刷新问题:返回之前打开的页面,走了create方法(解决)
  • IJCAI23 - Continual Learning Tutorial
  • 【YOLO v5 v7 v8 v9小目标改进】HTA:自注意力 + 通道注意力 + 重叠交叉注意力,提高细节识别、颜色表达、边缘清晰度
  • 外包干了10天,技术退步明显。。。。。
  • 如何在Win系统本地部署Jupyter Notbook交互笔记并结合内网穿透实现公网远程使用
  • 【自动化测试】之PO模式介绍及案例
  • 3D-Genome | Hi-C互作矩阵归一化指南
  • 【设计者模式】单例模式
  • Windows7缺失api-ms-win-crt-runtime-l1-1-0.dll的解决方法
  • coqui-ai/TTS 安装使用
  • Spring AOP相关注解及执行顺序
  • C++从零开始的打怪升级之路(day44)
  • [C++核心编程](七):类和对象——运算符重载*
  • 什么是MVC和MVVM
  • 物体检测-系列教程23:YOLOV5 源码解析13 (SPP层、Flatten模块、Concat模块、Classify模块)
  • 2024.3.6每日一题
  • YOLOSHOW - YOLOv5 / YOLOv7 / YOLOv8 / YOLOv9 基于 Pyside6 的图形化界面
  • sql高级
  • 更快更强,Claude 3全面超越GPT4,能归纳15万单词
  • devc++小游戏3.8.5
  • Java网络通信TCP
  • 层级锁笔记
  • 基于SpringBoot+Vue 的专家医院预约挂号系统
  • 计算机基础专升本笔记十二-Excel常用快捷键大全
  • 制作耳机壳的UV树脂和塑料材质相比优势有哪些?
  • JS(JavaScript)中如何实现,复选框checkbox多选功能
  • 直接修改zynq petalinux编译出来的rootfs.cpio.gz文件内容
  • 什么是 Golang 类型断言