当前位置:网站首页>Redis 缓存主动更新策略
Redis 缓存主动更新策略
2022-08-09 09:44:00 【ruochen】
- Cache Aside Pattern:由缓存的调用者,在更新数据库的同时更新缓存
- Read/Write Through Pattern:缓存与数据库整合为一个服务,由服务来维护一致性。调用者调用该服务,无需关心缓存一致性问题
- Write Behind Caching Pattern:调用者只操作缓存,由其他线程异步的将缓存数据持久化到数据库,保证最终一致
- 相对来讲,
Cache Aside Pattern
可靠性更高一点 - 操作缓存和数据库时要考虑如下几个问题 - 删除缓存还是更新缓存? - 更新缓存:每次更新数据库都更新缓存,无效写操作较多 - 删除缓存:更新数据库时让缓存失效,查询时再更新缓存(更优) - 如何保证缓存和数据库的操作的同时成功或失败?(原子性) - 单体系统:事务控制 - 分布式系统:利用TCC等分布式事务方案 - 先操作缓存还是先惭怍数据库?(线程安全) - 先删除缓存,再操作数据库 - 先操作数据库,再删除缓存 - 由于 redis 的速度远比 MySQL 要快,所以方案二为优选
在这里插入图片描述 - 缓存更新策略的最佳方案 - 低一致性需求:使用Redis自带的内存淘汰机制 - 高一致性需求:主动更新,并以超时剔除作为兜底方案 - 读操作: - 缓存命中则直接返回 - 缓存未命中则查询数据库,并写入缓存,设定超时时间 - 写操作: - 先写数据库,然后再删除缓存 - 要确保数据库与缓存操作的原子性
边栏推荐
猜你喜欢
快速解决MySQL插入中文数据时报错或乱码问题
免费下载天地图全国基础地理信息矢量数据的一种方法
Ontology Development Diary 05-Strive to Understand SWRL (Part 2)
Practical skills: a key for image information in the Harbor, quick query image
Tom Morgan | 人生二十一条法则
2021-04-26QGIS3.10加载天地图影像(地图瓦片)的一种方法
安装torch_sparse失败解决方法
Quick sort eight sorts (3) 】 【 (dynamic figure deduction Hoare, digging holes, front and rear pointer method)
[Machine Learning] Detailed explanation of web crawler combat
【个人学习总结】CRC校验原理及实现
随机推荐
字符串函数和内存函数
Celebrate ranked 18
Sweet alert
接口设计
Openwrt配置Aria2(Hg255d)
7.FileFilter interface
nacos从下载到安装集群的
EndNoteX9 OR X 20 Guide
Go-控制语句那些事
从源码分析UUID类的常用方法
2021-04-26QGIS3.10加载天地图影像(地图瓦片)的一种方法
程序环境和预处理
LeetCode75:颜色分类-C语言一次遍历求解
6.File类
mac 上安装Redis和配置
LPP code and its comments
3.练习Thread
2.Collection接口
【机器学习】数据科学基础——机器学习基础实践(二)
BigDecimal用法常用操作记录