Redis三种缓存读写策略

1. Cache Aside Pattern 旁路缓存模式

1.1 读

1.2 写

1.3 为什么要先更新db再删除cache?

缓存的写入速度是比数据库的写入速度快很多,因此相比于先删除cache后更新db带来数据不一致性问题的概率更小。

1.4 特点

  • 平时使用比较多的一个缓存读写模式
  • 同时维系db 和 cache,以db结果为准
  • 首次请求数据一定不在cache

2. Read/Write Through Pattern 读写穿透

2.1 读

2.2 写

2.3 特点

  • 在 Cache-Aside Pattern 之上进行了封装,cache 服务自己来写入缓存,对客户端是透明的
  • 首次请求数据一定不在cache
  • 把 cache 视为主要数据存储
  • 同步更新 cache 和 db

**3.**Write Behind Pattern 异步缓存写入

3.1 特点

  • 只更新缓存,不直接更新 db
  • 采用异步批量的方式来更新 db
  • 写性能非常高,适合数据经常变化但对数据一致性要求不高的场景
相关推荐
SelectDB3 小时前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶4 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵7 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils7 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
云技纵横10 小时前
一个 @Async 让循环依赖暴雷:Spring 代理的暗坑
redis
Databend1 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
犯困蛋挞yy1 天前
用Claude快速解决Redis代码报错反复无解的问题
redis
小七-七牛开发者2 天前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence2 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将2 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库