Redis缓存与数据库双写不一致及解决方法

1.缓存与数据库双写不一致

在大并发下,同时操作数据库与缓存会存在数据不一致性问题

1.1 双写不一致情况

1.2 读写并发不一致

2.解决方法

  • 对于并发几率很小的数据(如个人维度的订单数据、用户数据等),这种几乎不用考虑这个问题,很少会发生
    缓存不一致,可以给缓存数据加上过期时间,每隔一段时间触发读的主动更新即可。
  • 就算并发很高,如果业务上能容忍短时间的缓存数据不一致(如商品名称,商品分类菜单等),缓存加上过期
    时间依然可以解决大部分业务对于缓存的要求。
  • 如果不能容忍缓存数据不一致,可以通过加读写锁保证并发读写或写写的时候按顺序排好队,读读的时候相
    当于无锁。
  • 也可以用阿里开源的canal通过监听数据库的binlog日志及时的去修改缓存,但是引入了新的中间件,增加
    了系统的复杂度。
相关推荐
iAm_Ike1 小时前
Go 中自定义类型与基础类型间的显式类型转换详解
jvm·数据库·python
iuvtsrt1 小时前
Golang怎么实现方法集与接口的匹配_Golang如何理解值类型和指针类型实现接口的区别【详解】
jvm·数据库·python
難釋懷1 小时前
Redis数据结构-Set结构
数据结构·redis·bootstrap
tongluowan0072 小时前
MySQL中列数量及长度
数据库·mysql
-liming-2 小时前
单片机设计_串口调试工具
数据库·单片机·mongodb
鹿角片ljp3 小时前
从告警检测到智能研判:SQL 注入研判模型的设计与实践
数据库·sql
秋漓3 小时前
Redis学习笔记
redis
小新同学^O^4 小时前
简单学习 --> Spring事务
数据库·学习·spring
前进的李工4 小时前
MySQL慢查询日志优化实战
数据库·mysql·性能优化
KaMeidebaby4 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博