一:序数据库
- 最近在对数据作缓存时候,会涉及到如何保证 数据库/Redis 一致性问题。缓存
- 恰好今天来总结下 一致性问题 产生的问题,和可能存在的解决方案。网络
二:(更新策略)- 先更新数据库,后更新缓存spa
- 产生的问题blog
- 请求
- 由上面流程图可知道,请求A更新缓存应该比请求B更新缓存早才对,可是由于网络等缘由,B却比A更早更新了缓存。im
- 这就致使了脏数据,所以不考虑 先更新数据库,后更新缓存 这个更新策略。总结
三:(更新策略)- 先删除缓存,在更新数据库数据
- 产生的问题查询
-
- 若是同时有一个请求A进行更新操做,另外一个请求B进行查询操做。
- 就会致使不一致的情形出现。并且,若是不采用给缓存设置过时时间策略,该数据永远都是脏数据。
四:(更新策略)- 先更新数据库,在删除缓存
- FaceBook 也是采用这种方式。
- 固然,这种方式也会产生数据不一致问题。
- (1)缓存恰好失效
-(2)请求A查询数据库,得一个旧值
-(3)请求B将新值写入数据库
-(4)请求B删除缓存
-(5)请求A将查到的旧值写入缓存
- 前提是 写操做耗时必定是低于 读操做的,在通常的条件下,这时不可能得。
五:小结
- 这里只分析了日常可能想到的更新策略的分析。
- 其实,要解决数据一致性的问题,仍是要根据具体业务来具体判断。
- 强一致性的,那么就须要悲观锁,使得一致。
- 同时还有 延时双写/延时双删 等策略。其实都是为了根据自身业务来进行的操做。
- 知道了这些策略可能带来的问题,也就能够在合适的业务下选择合适的策略来知足咱们的需求。