怎么保证缓存和数据库数据的一致性?
1. 淘汰缓存:如果是较为复杂的数据时,进行缓存的更新操作就会变得异常复杂,因此一般推荐选择淘汰缓存,而不是更新缓存。
2. 选择先淘汰缓存,再更新数据库,假如先更新数据库再淘汰缓存,如果淘汰缓存失败,那么后面的请求都会得到脏数据,直至缓存过期。假如先淘汰缓存再更新数据库,如果更新数据库失败,只会产生一次缓存穿透,相比较而言,后者对业务则没有本质上的影响。
3. 延时双删策略 如下场景:同时有一个请求A进行更新操作,另一个请求B进行查询操作。 我们按如下步骤执行:
(1. 请求A进行写操作,删除缓存
(2. 请求B查询发现缓存不存在
(3. 请求B去数据库查询得到旧值
(4. 请求B将旧值写入缓存
(5. 请求A将新值写入数据库,次数便出现了数据不一致问题,此时我们可以采用延时双删策略得以解决。public void write(String key,Object data){ redisUtils.del(key); db.update(data); Thread.Sleep(100); redisUtils.del(key); }
这么做,可以将1秒内所造成的缓存脏数据,再次删除。这个时间设定可根据俄业务场景进行一个调节。
4. 数据库读写分离的场景 假如有如下场景: 两个请求,
一个请求A进行更新操作,另一个请求B进行查询操作。 我们按如下步骤执行:
1. 请求A进行写操作,删除缓存
2. 请求A将数据写入数据库了
3. 请求B查询缓存发现,缓存没有值
4. 请求B去从库查询,这时,还没有完成主从同步,因此查询到的是旧值
5. 请求B将旧值写入缓存
6. 数据库完成主从同步,从库变为新值 依旧采用延时双删策略解决此问题。
猜你喜欢LIKE
相关推荐HOT
更多>>什么是XSS攻击,如何避免?
所以XSS攻击的核心就是浏览器渲染DOM的时候将文本信息解析成JS脚本从而引发JS脚本注入,那么XSS攻击的防御手段就是基于浏览器渲染这一步去做防...详情>>
2022-11-17 11:36:00java入门基础知识
新手学习java会有一定的难度,初期阶段可能会不知道如何规划学习路线,建议大家可以上网直接寻找一些成熟的java学习大纲,比如一些java培训机...详情>>
2022-10-19 14:04:00怎么保证缓存和数据库数据的一致性?
选择先淘汰缓存,再更新数据库,假如先更新数据库再淘汰缓存,如果淘汰缓存失败,那么后面的请求都会得到脏数据,直至缓存过期。假如先淘汰缓存...详情>>
2022-10-10 09:51:00请解释自动装配模式的区别?
有五种自动装配的方式,可以用来指导 Spring 容器用自动装配方式来进行依赖注入。 1. no 默认的方式是不进行自动装配,通过显式设置ref属性来...详情>>
2022-10-10 09:50:00如何搭建一个高可用的系统?
高可用系统,就是说要保证系统在几乎任务时候都要有正常运行,功能正常。 我们来看下哪些情况会造成系统不可用。- 单机系统下的可用性问题,从n...详情>>
2022-10-10 09:50:00Java培训问答更多>>
新Java行业疑惑解答:Java的内存管理是如何工作的?
新java script是什么?为什么要学java script
新java和大数据哪个好?未来哪个职业发展更好
新java培训班多久能学会?培训周期大概多久
新java script和java的区别有哪些?如何区分
新java script的数据类型主要有哪些?怎样学的更快
新c语言与java区别在哪里?去培训机构学哪个比较好
Java面试题库 更多>>
华为外包java面试题-Java实现单链表的逆序
Java程序员面试题
Java面试题及答案
什么是线程的上下文切换?
如何撤销已经推送(push)到远端仓库的提交(commit)信息?
你了解哪些加密算法?
- 北京校区
- 大连校区
- 广州校区
- 成都校区
- 杭州校区
- 长沙校区
- 合肥校区
- 南京校区
- 上海校区
- 深圳校区
- 武汉校区
- 郑州校区
- 西安校区
- 青岛校区
- 重庆校区
- 太原校区
- 沈阳校区
- 南昌校区
- 哈尔滨校区