ruochen
Redis 缓存主动更新策略
原创
关注作者
前往小程序,Get
更优
阅读体验!
立即前往
腾讯云
开发者社区
文档
建议反馈
控制台
登录/注册
首页
学习
活动
专区
工具
TVP
最新优惠活动
文章/答案/技术大牛
搜索
搜索
关闭
发布
首页
学习
活动
专区
工具
TVP
最新优惠活动
返回腾讯云官网
ruochen
首页
学习
活动
专区
工具
TVP
最新优惠活动
返回腾讯云官网
社区首页
>
专栏
>
Redis 缓存主动更新策略
Redis 缓存主动更新策略
原创
ruochen
关注
发布于 2022-08-09 08:45:34
4.1K
0
发布于 2022-08-09 08:45:34
举报
文章被收录于专栏:
若尘的技术专栏
Cache Aside Pattern:由缓存的调用者,在更新数据库的同时更新缓存
Read/Write Through Pattern:缓存与数据库整合为一个服务,由服务来维护一致性。调用者调用该服务,无需关心缓存一致性问题
Write Behind Caching Pattern:调用者只操作缓存,由其他线程异步的将缓存数据持久化到数据库,保证最终一致
相对来讲,
Cache Aside Pattern
可靠性更高一点
操作缓存和数据库时要考虑如下几个问题 - 删除缓存还是更新缓存? - 更新缓存:每次更新数据库都更新缓存,无效写操作较多 - 删除缓存:更新数据库时让缓存失效,查询时再更新缓存(
更优
) - 如何保证缓存和数据库的操作的同时成功或失败?(原子性) - 单体系统:事务控制 - 分布式系统:利用TCC等分布式事务方案 - 先操作缓存还是先惭怍数据库?(线程安全) - 先删除缓存,再操作数据库 - 先操作数据库,再删除缓存 - 由于 redis 的速度远比 MySQL 要快,所以方案二为优选
在这里插入图片描述
缓存更新策略的最佳方案 - 低一致性需求:使用Redis自带的内存淘汰机制 - 高一致性需求:主动更新,并以超时剔除作为兜底方案 - 读操作: - 缓存命中则直接返回 - 缓存未命中则查询数据库,并写入缓存,设定超时时间 - 写操作: - 先写数据库,然后再删除缓存 - 要确保数据库与缓存操作的原子性
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系
cloudcommunity@tencent.com
删除。
云数据库 Redis
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系
cloudcommunity@tencent.com
删除。
云数据库 Redis
#redis
#缓存
评论
登录
后参与评论
0 条评论
热度
最新
推荐阅读
LV.
文章
0
获赞
0
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
产品介绍
产品文档
云数据库采购特惠,高性能、高可靠、高安全,超值优惠等你享!
领券
问题归档
专栏文章
快讯文章归档
关键词归档
开发者手册归档
开发者手册 Section 归档
0
0
0
推荐