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

如何保证数据库和缓存一致性问题

如何保证数据库和缓存一致性问题

我刚开始以为数据一致性指的是不同请求拿到的数据是一样的,但是这个对于一致性的定义其实是强一致性。

为了保证系统的可用性和性能,我们选择的是牺牲强一致性来获取最终一致性,那么接下来我们只需要保证最终一致性而无需考虑整个过程中的数据强一致性。我们使用的是旁路缓存的方式。

对于读策略,如果缓存没有过期,直接读取即可。如果缓存过期,可以选择客户端线程或者是redis的后台线程去读数据库的数据,然后更新到缓存中,最后再返回给客户端。

对于写策略,有两种方式,先更新数据库,后删缓存。先删缓存,后更新数据库。

对于先删缓存,后更新数据库来说,假设线程A删缓存,此时线程B访问数据,发现数据不在缓存中。那么线程B需要去数据库中获取数据再将数据放到缓存中,等到线程A更新完数据库后,此时数据库和缓存中的数据不一样,无法保证最终一致性。对于先更新数据库,后删缓存来说,线程A先进行数据库的更新,此时线程B访问缓存有数据直接返回,接着线程A再进行缓存的删除,此时可以保证缓存和数据库的一致性。后续请求访问缓存时,没有命中会到数据库中进行获取对应数据。有一种特殊情况,线程B在缓存中没有找到数据,去数据库中进行数据的查找,线程A更新数据库,等到线程A删除缓存中的数据后,线程B再将之前获取的数据放到缓存中。由于线程B拿到的数据是在线程A更新数据库之前的,那么此时会存在数据库和缓存数据不一致的问题,但是这样的概率会很低,因为将数据写到缓存中的速度大于线程A更新数据库的速度

删除缓存一般存在两种方式:通过设置数据的过期时间和直接删除的方式。

通过设置数据的过期时间比较麻烦,设置过小,缓存没有起到缓存效果,请求会发到数据库中,造成数据库的压力。设置过大,缓存和数据库之间数据延迟较大,且浪费内存。

因此我们选择直接删除的方式来进行优化。此时我们需要保证直接删除能够成功,否则旧有数据一直存放到缓存中,会造成数据一致性问题。


对于直接删除数据会有两种方式。

一种是删除数据重试策略,我们会将需要删除的数据放在消息队列中,由客户端去获取需要删除的数据,尝试删除,如果删除成功那么将消息从消息队列中进行移除,如果没有成功那么重新尝试几次。尝试几次依然没有成功,需要向业务层反馈这个问题。

这种方式缺点是我们需要通过在代码中写死向mq队列发送特定要删除的数据。

另外一种是通过订阅binlog + canal + 消息队列方式。我们通过订阅binlog,将数据解析为结构化数据存放到消息队列中,接着编写一个简单的消费数据的消费者订阅mq,接着通过获取数据的key来完成删除操作。通过ack机制来保证数据一致性问题。

这种方式我们通过订阅binlog。数据发生更新,此时binlog会发生改动,那么canal能够察觉binlog的变化并将改动后的信息发送给mq。这样子并不需要我们硬编码,来完成数据的删除操作。缺点是实现起来比较麻烦。

http://www.jsqmd.com/news/107113/

相关文章:

  • Lime编辑器:终极开源解决方案能否终结代码编辑器的选择困境?
  • Web开发者进阶AI Agent:基于LlamaIndex构建企业级RAG Pipeline实战
  • MiniGPT-4效率优化实战:3倍性能提升的系统架构重构
  • 实战生成式AI测试数据解决方案:从诊断到部署的完整架构
  • YOLO系列学习三(训练):
  • 易控:3分钟学会手机远程控制手机的终极指南 [特殊字符]→[特殊字符]
  • 快速上手CT肺部自动分割:lungmask终极使用指南
  • LaTeX3编程革命:从传统宏包到现代结构化开发
  • Lucky ACME证书自动化管理:告别手动续期,拥抱智能HTTPS安全
  • Uppy智能文件过滤:从混乱上传到精准控制的革命性方案
  • 企业AI开发新革命:如何用MCP协议打造智能应用生态
  • 反向代理与 Forwarded 相关 Header 深度解析
  • GLM-4.5-FP8:如何用开源大模型实现高效AI推理
  • AI销售自动化与客户管理的最佳获客软件选择--VertGrow AI销冠
  • 图片查看工具:专业级跨平台图像浏览解决方案
  • break和continue的区别是什么?
  • jetty9配置contextPath
  • NanoPi R5S能否成为你的千兆网络新宠?实测数据告诉你答案
  • 广东AI数字人/智能体/智能化改造/AI一体机/AI搜索推广公司首选湾西小冰——深耕区域AI服务,赋能产业数字化转型 - 全局中转站
  • SeedVR2-7B完整使用指南:三步实现AI视频质量飞跃
  • MouseTester深度评测:数据驱动的鼠标性能精准诊断方案
  • 21 . 字母异位词分组
  • Web开发者快速上手AI Agent:基于提示工程的旅游攻略系统实战
  • 微算法科技(NASDAQ MLGO)区块链混合检测模型优化确保全网防御策略一致性
  • Mermaid Live Editor 终极指南:实时图表编辑的完整解决方案
  • Amazon Bedrock × Claude 实战:从扫描文档到结构化数据的智能处理流程
  • FastSAM自定义数据集终极指南:从零到一的完整流程
  • 实战指南:基于ffmpeg-python构建智能视频质量控制系统
  • AI驱动测试数据生成:从挑战到落地的实战路线图
  • Linux内核信号机制深入解析:高级技巧与进程通信优化