redis 如何保证缓存和数据库一致性?解决策略如下

Redis 与数据库的数据保持一致,传统策略是先读缓存,未命中则读数据库并回填缓存,但方式这种维护成本较高。

下面是几种传统常见的策略及其优缺点:

【策略1】先写 MySQL。成功后,更新或删除 Redis 中的对应数据。

  • 优点:简单易实现。
  • 缺点:存在短暂的不一致。

【策略2】先写 Redis。异步或定时将Redis数据同步到 MySQL。

  • 优点:提升写性能。
  • 缺点:同步延迟可能导致数据丢失。

【策略3】读 Redis,命中则返回,未命中则读 MySQL,并将结果写入 Redis。

  • 优点:减少 MySQL 压力。
  • 缺点:存在短暂的不一致。

【策略4】数据同步写入 MySQL 后,发送消息到消息队列,消费者读取消息并更新 Redis。

  • 优点:解耦,提升可靠性。
  • 缺点:系统复杂度增加。

【策略5】为 Redis 数据设置过期时间,过期后重新从 MySQL 加载。

  • 优点:自动处理不一致。
  • 缺点:过期时间内可能存在不一致。

传统策略(Redis+MySQL)的形式往往需要技术人员定期维护。

目前国内云厂商数据库很多采用磁盘 kv 存储,内存 + 磁盘结合的方式,比如百度智能云 PegaDB、阿里磁盘型 Tair 等等。

相关推荐
爬山算法35 分钟前
Redis(50) Redis哨兵如何与客户端进行交互?
数据库·redis·交互
007php00739 分钟前
某大厂MySQL面试之SQL注入触点发现与SQLMap测试
数据库·python·sql·mysql·面试·职场和发展·golang
YS_Geo1 小时前
Redis 深度解析:数据结构、持久化与集群
数据结构·数据库·redis
IvanCodes1 小时前
六、Docker 核心技术:Dockerfile 指令详解
java·数据库·docker
寻星探路1 小时前
数据结构造神计划第三天---数据类型
数据库
YUELEI1181 小时前
langchain 缓存 Caching
缓存·langchain
孤独的人2 小时前
WordPress 性能优化:从插件到 CDN 的全方位缓存设置指南
spring·缓存·性能优化
l5657582 小时前
第五十五天(SQL注入&增删改查&HTTP头&UA&XFF&Referer&Cookie&无回显报错&复盘)
数据库
上海达策TECHSONIC2 小时前
经验分享:如何让SAP B1数据库性能提升50%
运维·数据库·运维开发
牛奶咖啡132 小时前
Nginx+Tomcat集群Redis共享session方案
redis·nginx·tomcat·redisson·分布式session共享方案·分布式session实现·jdk1.8环境安装