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

分布式缓存数据一致性-解决方案

  1. 如果是用户维度,并发几率小(用户修改订单)。不需要考虑一致性问题,缓存数据加上过期时间,每隔一段时间出发读数据,主动更新缓存即可。(缓存过期删除数据,触发读请求主动更新,查询缓存null-> mysql->存到缓存->返回)
  2. 如果是菜单、商品介绍这种对时实性要求不高的数据,允许缓存不一致。可以使用canel订阅binlog的方式。
  3. 缓存数据加过期时间,足以解决大部分的业务的对于缓存的要求。
  4. 通过读写锁保证并发读写,写写的时候按照先后顺序排队。读读无所谓,有写操作的时候,使用读写锁。(业务不关心临时脏数据的,可忽略)

总结
5. 对于实时性、数据一致性要求高的数据,不应该存入缓存,这种直接查询数据库,即使慢点也没事。
6. 实时性一致性要求不高的,在缓存中加上自动过期时间,保证当天拿到最新的数据即可(缓存过期删除后,可以触发读自动更新缓存)。
7. 不应该过度增加数据库的写、读复杂性。

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

相关文章:

  • Java设计模式-享元模式
  • idea模块的pom.xml被划横线,不识别的解决办法
  • ffmpeg 中 av_log 是怎样工作的?
  • HTML+CSS+JavaScript:轮播图自动播放
  • python 自动化数据提取之正则表达式
  • 分布式事务之本地事务
  • PyTorch 初级教程:构建你的第一个神经网络
  • SpringBoot使用MyBatis Plus + 自动更新数据表
  • 【设计模式】简单工厂模式
  • 推荐系统-ALS协同过滤算法实现
  • QT第三讲
  • Linux内核的I2C驱动框架详解------这应该是我目前600多篇博客中耗时最长的一篇博客
  • 【点云处理教程】05-Python 中的点云分割
  • 代码随想录算法训练营之JAVA|第十七天| 654. 最大二叉树
  • C++重写函数、隐藏函数、重载函数的区别对比
  • 15.python设计模式【函数工厂模式】
  • Redis主从复制、哨兵、cluster集群原理+实验
  • 微信小程序如何实现页面传参?
  • OPC DA 客户端与服务器的那点事
  • Java 错误异常介绍(Exceptions)
  • 每日一题——旋转数组的最小数字
  • SpringBoot Jackson 日期格式化统一配置
  • 剑指 Offer 38. 字符串的排列 / LeetCode 47. 全排列 II(回溯法)
  • 【前端知识】React 基础巩固(四十三)——Effect Hook
  • 一百三十八、ClickHouse——使用clickhouse-backup备份ClickHouse库表
  • 【无标题】使用Debate Dynamics在知识图谱上进行推理(2020)7.31
  • windows下若依vue项目部署
  • 【目标检测】基于yolov5的水下垃圾检测(附代码和数据集,7684张图片)
  • P1734 最大约数和
  • Excel将单元格中的json本文格式化