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

缓存数据库一致性

文章目录常用的一致性策略Cache Aside旁路缓存read through或write throughwrite back写请求先写缓存还是先写数据库写缓存还是删除缓存怎么操作才能保证缓存和数据库的一致性先更新缓存再更新数据库先更新数据库再更新缓存先删除缓存再更新数据库延迟双删先更新数据库再删除缓存说明常用的一致性策略Cache Aside旁路缓存定义读请求先从缓存中去读读不到再从数据库中读然后写入缓存特点业务代码既要操作缓存又要操作数据库以数据库的数据为主缓存只是暂时存储数据而已。read through或write through设计思想不直接操作数据库只操作缓存然后让缓存自身去操作数据库。定义read through指每次读都要读缓存如果有就返回数据没有缓存自身从数据库中读数据然后写入缓存write through指写数据的时候直接写缓存缓存自身去更新数据库。也就是说我们只需操作缓存即可剩余操作由缓存中间件自身去完成。write back定义只操作缓存然后让缓存自身去操作数据库。与上面不同之处是写回是批量的、异步的去写数据库。适合写多读少的场景。但是由于是异步写入数据库所以有数据丢失的风险。写请求先写缓存还是先写数据库写缓存还是删除缓存怎么操作才能保证缓存和数据库的一致性先更新缓存再更新数据库可以看到此时缓存值为B数据库值为A出现缓存和数据库不一致。因为更新缓存和数据库的操作不是原子性的所以会出现并发问题。先更新数据库再更新缓存可以看到此时缓存值为A数据库值为B也出现缓存和数据库不一致。先删除缓存再更新数据库这个方法也会出现缓存和数据库不一致的情况延迟双删先删除缓存再更新数据库让线程等待一会儿然后再删数据库。为什么要等一会再删这是要让另外一个线程能在等一会的这个时间去完成读数据库并写缓存这个操作然后给它删了。那么问题来了要延迟多久等多久这要考虑当时的网络情况怎么样服务器的负载和数据库的负载等情况没有一个标准的时间。先更新数据库再删除缓存这个方法也会出现不一致的情况但是概率非常小因为必须满足两个条件刚好是这个 key 刚好过期然后刚好又要更新数据请求2刚更新完数据然后删除缓存之后请求1才写入缓存。也就是说写缓存的速度要慢于更新数据库删除缓存的速度这个概率是非常低的。所以先更新数据库再删除缓存在绝大多数情况下都是可行的。那么问题来了如果更新数据库成功删除缓存失败了怎么解决呢把删除缓存的操作放到 MQ 中MQ 去异步地删除缓存。如果删除失败了那就重试。监听数据库的bin log更新数据库成功会产生一条bin log因此就可以监听这个bin log然后删除缓存。同样地如果删除失败了那就重试。这个方法的优点是不入侵业务代码比使用 MQ 的方案好。但是实际上公司的 MySQL 都是主从部署读写分离的主库只能写从库只能读然后主库更新的数据需要花一点时间同步给从库。所以当请求1先更新了这个数据库然后异步地删除了缓存但是写的是主库从库还没写从库需要等待主库同步数据过来那从库还没等到主库传来的数据此时又来了一个请求读了从库的旧数据然后写入了缓存缓存和数据库又出现不一致了但是这种概率也是非常低的如果非要解决这个问题那可以在主库更新之后的一段时间之内让其他请求强制去读主。综上所述要想保证缓存和数据库的完全一致性几乎是完全不可能的现有的手段只能尽可能地去保证缓存和数据库在绝大多数的情况下是一致的然后给数据设置一个过期时间。即便在非常极端的情况下不一致了也能让这个脏数据过期失效。说明本文参考程序员回家养猪博主的视频进行总结和编写。

相关文章:

缓存数据库一致性

文章目录常用的一致性策略Cache Aside旁路缓存read through或write throughwrite back写请求先写缓存还是先写数据库,写缓存还是删除缓存,怎么操作才能保证缓存和数据库的一致性?先更新缓存,再更新数据库先更新数据库,…...

汽车HiL测试与测量建模技术解析

1. 汽车HiL测试与测量建模技术概述在汽车电子控制系统开发领域,基于测量的建模(Measurement Based Modeling)已经成为现代开发流程中不可或缺的核心技术。这种方法通过采集真实系统的输入输出数据,构建精确的数学模型,…...

从基础到定制:探索 <video> 标签的 controls 与 controlslist 属性

1. 初识 <video> 标签的 controls 属性 想象一下&#xff0c;你正在搭建一个在线教育平台&#xff0c;需要让学生能够流畅观看课程视频。这时候&#xff0c;controls 属性就是你的好帮手。这个看似简单的属性&#xff0c;实际上封装了浏览器原生视频播放器的完整交互能力…...

Qwen3.5-9B开源大模型教程:从HuggingFace下载到本地WebUI上线

Qwen3.5-9B开源大模型教程&#xff1a;从HuggingFace下载到本地WebUI上线 1. 项目概述 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型&#xff0c;具备强大的逻辑推理、代码生成和多轮对话能力。最新版本还支持多模态理解&#xff08;图文输入&#xff09;和长达128K tokens…...

从K-means到DBSCAN:六种聚类算法实战场景与Python代码解析

1. 聚类算法入门&#xff1a;从超市货架到数据分群 第一次接触聚类算法时&#xff0c;我正站在超市的饮料区发呆。货架上的饮料被分门别类摆放&#xff1a;碳酸饮料、果汁、矿泉水、功能饮料...这其实就是最直观的聚类场景。在数据科学中&#xff0c;聚类算法就是帮我们完成类似…...

实战技巧:AI项目中常用的10个开源工具推荐

模型库的“一站式商店” 大模型应用的“脚手架” RAG系统的“数据管家” Ray&#xff1a;分布式训练的“调度大师” vLLM&#xff1a;大模型推理的“速度之王” Gradio&#xff1a;AI应用的“极速展示台” FastAPI&#xff1a;API服务的“高性能框架” MLflow&#xff1…...

树莓派4B+nrf52840 dongle搭建Thread边界路由保姆级教程(含常见错误排查)

树莓派4B与nrf52840 dongle构建Thread边界路由全流程解析 在智能家居和物联网领域&#xff0c;Thread协议因其低功耗、高安全性和自愈网络特性正获得越来越多的关注。作为基于IPv6的无线mesh网络协议&#xff0c;Thread能够为智能设备提供稳定可靠的连接&#xff0c;而边界路由…...

GOOSE协议深度解析:从报文帧结构到变电站实时通信实战

1. GOOSE协议在变电站自动化中的核心地位 我第一次接触GOOSE协议是在2015年参与某500kV智能变电站改造项目时。当时看到保护装置之间通过网线替代了传统的硬接线&#xff0c;心里直打鼓——这些看似脆弱的网线真能承担起保护跳闸这样的关键任务吗&#xff1f;直到亲眼目睹了断路…...

避坑指南:STM32F103多通道捕获中断冲突的5种解决方案

STM32F103多通道捕获中断冲突的实战解决方案 在嵌入式开发中&#xff0c;定时器的多通道捕获功能常用于测量脉冲宽度、频率等信号特征。STM32F103系列作为经典微控制器&#xff0c;其TIM5定时器支持四个独立通道的输入捕获。然而&#xff0c;当同时使用多个通道时&#xff0c;开…...

Linux-parted命令

创作背景Gkit部署环境的时候遇到一个报错&#xff0c;管理域准备环节报错内容如下&#xff1a;[2026-04-02 16:20:21] Error Log:Parted failed, result is [ parted: invalid token: logicError: Expecting a partition type. ] when exec: [ sudo parted -s /dev/vdb mkpar…...

从STM32F407到大疆A板:工创赛智能物流小车主控选型避坑与实战心得

从STM32F407到大疆A板&#xff1a;工创赛智能物流小车主控选型避坑与实战心得 在嵌入式竞赛的备战过程中&#xff0c;主控板的选择往往决定了整个项目的成败。作为经历过省赛和国赛双重考验的团队&#xff0c;我们深刻体会到&#xff1a;一块合适的主控板不仅能提升开发效率&am…...

Windows 下 OpenClaw 快速搭建与使用指南

前言 2026年爆火的开源AI智能体 OpenClaw&#xff08;昵称小龙虾&#xff09;&#xff0c;GitHub星标超28万&#xff0c;凭"本地运行零代码自动干活"圈粉无数&#xff01;本文专为小白打造&#xff0c;用自制的一键部署包&#xff0c;无需命令行、无需手动配环境&am…...

IEEE 802.3u是1995年发布的快速以太网标准,将以太网传输速率从10Mbps提升至100Mbps

本报告基于《软件设计师教程》第10章"网络与信息安全基础知识"的内容&#xff0c;结合网络资源对快速以太网&#xff08;IEEE 802.3u&#xff09;、千兆以太网&#xff08;IEEE 802.3z&#xff09;和令牌环网&#xff08;IEEE 802.5&#xff09;三大局域网标准进行详…...

OpenClaw 完整安装教程与最新版安装包

摘要&#xff1a;2026年爆火的开源AI智能体OpenClaw&#xff08;昵称小龙虾&#xff09;&#xff0c;GitHub星标超28万&#xff0c;凭"本地运行零代码自动干活"圈粉无数&#xff01;本文专为小白打造&#xff0c;用自制的一键部署包&#xff0c;无需命令行、无需手动…...

PowerDMIS 新建坐标系

坐标系创建按键&#xff0c;用于3-2-1坐标系/迭代坐标系/最佳拟合坐标系/偏置坐标系的命令3-2-1 法坐标系1&#xff08;PCS3-2-1法&#xff09; 适用工件&#xff1a;3-2-1法适用于具有规则形状、明确的平面、直线、孔、槽、边缘等的零件的工件坐标系创建的常用方法。 优势&…...

并发的核心特征可以概括为:**宏观上同时执行,微观上交替执行**。在多任务操作系统中,多个程序在同一时间段内同时推进

并发的核心特征可以概括为&#xff1a;宏观上同时执行&#xff0c;微观上交替执行。在多任务操作系统中&#xff0c;多个程序在同一时间段内同时推进&#xff0c;从宏观角度看用户感知到多个任务在同时运行&#xff1b;但在微观层面&#xff0c;单个CPU核心在任意时刻只能执行一…...

太空算力:下一个万亿蓝海赛道

当我们谈论算力时&#xff0c;脑海中浮现的往往是数据中心里密密麻麻的服务器机柜&#xff0c;或者高性能计算机嗡嗡作响的散热风扇。但你是否想过&#xff0c;有一天&#xff0c;算力也可以“搬”到太空去&#xff1f;2026年4月3日&#xff0c;北京经济技术开发区通明湖会展中…...

OpenAI惨遭反超,Anthropic狂吞70%新客户,Claude已开启「灵魂校准」

当企业真金白银开始从 ChatGPT 流向 Claude&#xff0c;Anthropic 打的早已不只是模型性能战&#xff0c;而是一场从工程师口碑、企业信任到「AI灵魂校准」的全面突围。 这一次&#xff0c;Anthropic真的要把OpenAI从「企业AI王座」上拽下来了。 美国企业财务卡发行商 Ramp 最…...

被AGI逼疯的硅谷天才,正在集体逃亡

OpenAI 工程师因严重精神透支辞职回国&#xff0c;撕开了硅谷 AI 圈残酷的内卷真相。在「0-0-2」极限压榨与道德焦虑双重折磨下&#xff0c;xAI、OpenAI 等巨头的核心研发骨干正掀起一场史无前例的集体逃亡。 OpenAI 工程师 Hieu Pham 终于不得不决定彻底停止工作&#xff0c;…...

Excel也能玩转熵权法?手把手教你不用编程做指标权重分析

Excel也能玩转熵权法&#xff1f;手把手教你不用编程做指标权重分析 在业务分析中&#xff0c;我们常常需要评估多个指标的相对重要性。比如产品经理需要确定用户满意度调查中各维度的权重&#xff0c;运营人员要量化活动效果评估中不同KPI的贡献度。传统的主观赋权方法容易受个…...

洛谷-算法1-7-搜索4

P1596 [USACO10OCT] Lake Counting S 题目描述 由于最近的降雨&#xff0c;水在农夫约翰的田地里积聚了。田地可以表示为一个 NM 的矩形&#xff08;1≤N≤100&#xff1b;1≤M≤100&#xff09;。每个方格中要么是水&#xff08;W&#xff09;&#xff0c;要么是干地&#x…...

11《深入解析CAN总线:数据场、控制场、CRC场逐字段精讲》

001、CAN总线协议基础与帧结构总览 从一次诡异的通信丢帧说起 上个月在调试一个电机控制节点时,遇到个怪事:总线上明明能看到正确的ID和DLC,但数据场内容偶尔会错乱。逻辑分析仪抓到的波形显示,CRC校验段居然通过了,但应用层解析出来的转速值会突然跳变。查了三天,最后…...

网络传输介质是计算机网络中连接各个节点的物理通路,是数据传输的物理基础

网络传输介质是计算机网络中连接各个节点的物理通路&#xff0c;是数据传输的物理基础。根据《软件设计师教程&#xff08;第5版&#xff09;》内容&#xff0c;传输介质主要分为有线传输介质和无线传输介质两大类&#xff0c;以下是各类介质的核心特性&#xff1a; 1. 同轴电缆…...

记一次由「进程文件描述符泄漏」引发的socket- too many open files

记一次由「进程文件描述符泄漏」引发的socket: too many open files 在运维和开发过程中&#xff0c;文件描述符泄漏是一个常见但容易被忽视的问题。当进程频繁打开文件、网络连接等资源却未正确关闭时&#xff0c;系统资源会被逐渐耗尽&#xff0c;最终导致"too many op…...

免费零投入,每月帮打工人省18小时少花200块,2026新版会议纪要模板不领亏大了

我做了五年社科访谈研究&#xff0c;前四年大半时间都耗在录音整理上&#xff0c;踩过不下十种语音转写工具的坑&#xff0c;要么准确率低改到疯&#xff0c;要么收费贵一年大几百&#xff0c;要么长音频直接卡崩溃。试了一圈下来&#xff0c;我可以明确说&#xff1a;听脑AI是…...

[具身智能-379]:如何在仿真环境进行模型的训练?模型如何获取仿真如何的数据?模型与仿真软件交换信息的标准?

一、仿真环境训练模型的标准流程无论使用强化学习&#xff08;RL&#xff09;、监督学习&#xff08;SL&#xff09;还是模仿学习&#xff08;IL&#xff09;&#xff0c;在仿真中训练都遵循以下闭环&#xff1a;1. 环境配置2. 定义交互接口3. 构建训练循环4. 并行加速5. 评估与…...

ECharts 3D地图多层级同步交互优化:零延迟缩放与拖拽实战

1. 为什么需要3D地图多层级同步交互&#xff1f; 最近在做数据可视化项目时&#xff0c;遇到了一个棘手的问题&#xff1a;如何在ECharts的3D地图中实现多个geo图层的同步缩放和拖拽&#xff1f;这个问题看似简单&#xff0c;但实际操作起来却有不少坑。想象一下&#xff0c;当…...

三点定圆心半径易语言实现

要使用易语言实现三点确定圆心与半径的计算&#xff0c;核心是基于平面几何原理&#xff1a;三个不共线的点可以唯一确定一个圆&#xff0c;圆心到这三个点的距离相等。以下是具体的实现方法和代码。 一、算法原理与数学推导 1.1 核心数学公式 设三个点坐标为 $P_1(x_1, y_1…...

【赵渝强老师】OceanBase的分区表

OceanBase当前支持的类型包括Range分区、Range COLUMNS分区、List分区、List COLUMNS分区、Hash分区和Key分区等&#xff0c;其中&#xff1a; Range分区、Range COLUMNS分区、List分区和List COLUMNS分区可以用于解决业务中大量删除带来的性能问题&#xff0c;支持快速删除分…...

AI大模型时代的企业可观测性架构设计方案

一、架构设计原则&#xff1a;AI原生可观测性的核心理念1. 统一标准&#xff0c;打破数据孤岛在AI大模型时代&#xff0c;传统的割裂式监控工具&#xff08;如Prometheus监控基础设施、ELK日志分析、Jaeger链路追踪&#xff09;已无法满足复杂AI系统的可观测需求。必须采用Open…...