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

12.29 redis缓存一致性

更新操作
如果先更新数据库再更新缓存

  1. 先更新缓存再更新数据库
    更新缓存为1
    更新缓存尾2
    更新数据库为2
    更新数据库为1
    那么最后缓存为2
    数据库为1
    数据不一致

  2. 先更新数据库,再更新缓存
    数据库为1
    数据库为2
    缓存为2
    缓存为1
    还是不一致

于是这种情况我们改为将缓存删除

  1. 先删除缓存,再更新数据库
    删除缓存
    读缓存,未命中
    写回缓存
    更新数据库

这样也会数据不一致

4.先更新数据库,再删除缓存
读缓存
读到的是以前缓存
更新数据库
删除缓存
写回

这也会数据不一致
但是这种几率比较小
因为先写回的速度要快于更新数据库

就是先更新数据库再删除缓存

先删除缓存再更新数据库会有问题码?

先删除缓存,然后这时候另外一个线程没读到,就会读取数据库然后写回缓存,然后数据库更新之后,就数据不一致了

然后后删除,因为先更新数据库,那么即使读取数据,没有读到,读数据库,就会写回到缓存,然数据库更新之后,会把这个写回值删除掉,由于更新数据库的速度比较慢,所以并不会写回在删除之后

说说缓存更新策略

旁路缓存
就是最常用的我们先更新数据库,然后再删除缓存
然后读的时候命中了直接返回吗,没命中的话,我们就读数据库,然后写回缓存
写穿/读穿
就是写到数据库的时候就写到缓存中去
写回
在cpu中,就是只写在缓存中,只有cache满了要被替换的时候才写道内存中

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

相关文章:

  • SqlSugar配置连接达梦数据库集群
  • 评分模型在路网通勤习惯分析中的应用——提出问题(1)
  • 使用 OpenCV 绘制线条和矩形
  • npm 切换镜像源
  • CSS(四)display和float
  • MMaudio AI:如何通过 AI 实现精准的视频到音频合成
  • SQL进阶技巧:如何分析双重职务问题?
  • OpenCV相机标定与3D重建(37)计算两幅图像之间单应性矩阵(Homography Matrix)的函数findHomography()的使用
  • Nacos配置管理+共享配置、配置热更新
  • asp.net core系统记录当前在线人数
  • 秒杀场景的设计思考
  • 快速掌握Haproxy原理架构
  • 基于Centos7.X系统端口占用处理
  • MySQL的索引失效的原因有那些
  • Java重要面试名词整理(十):Kafka
  • 内置ALC的前置放大器D2538A/D3308
  • 04-微服务02
  • Java中的this关键字详解:深入理解与应用
  • 2、C#基于.net framework的应用开发实战编程 - 设计(二、四) - 编程手把手系列文章...
  • 设置首选网络类型以及调用Android框架层的隐藏API
  • “Gold-YOLO:基于聚合与分发机制的高效目标检测新范式”
  • 神经网络-AlexNet
  • Hutool 发送 HTTP 请求的几种常见写法
  • 【Linux】进度条
  • 【zookeeper核心源码解析】第四课:客户端与服务端读写的io核心流程
  • 强化学习蘑菇书笔记
  • 《机器学习》——线性回归模型
  • Linux(Centos 7.6)网卡信息没有了问题处理
  • WEB攻防-通用漏洞-文件上传-js验证-MIME验证-user.ini-语言特征
  • mybatis-plus代码生成器