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 等等。

相关推荐
冉冰学姐1 分钟前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly8 分钟前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
Elastic 中国社区官方博客16 分钟前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.20 分钟前
MYSQL--- 聚合查询,分组查询和联合查询
数据库
一 乐24 分钟前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
啦啦啦_999927 分钟前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学1 小时前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
Exquisite.1 小时前
Mysql
数据库·mysql
fengxin_rou1 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
全栈前端老曹1 小时前
【MongoDB】深入研究副本集与高可用性——Replica Set 架构、故障转移、读写分离
前端·javascript·数据库·mongodb·架构·nosql·副本集