到底是先操作数据库还是先操作缓存,取决于哪种方案可以避免数据不一致,或者数据不一致的概率更低。下面的分析会基于Cache Aside策略展开,为什么基于Cache Aside策略,请查看博文“缓存更新策略”

方案1:先缓存再数据库

  先缓存再数据库的方案,在并发读写情况下,会出现数据不一致的情况,如下图所示。而且,这种不一致情况会伴随着并发量的上升而严重(换句话说,并发量越大,出现的概率越大)。
缓存 —— 先数据库还是先缓存(2)

方案2:先数据库再缓存

  先数据库再缓存的方案,在删除缓存失败的情况下,会出现数据不一致的情况,如下图所示。
缓存 —— 先数据库还是先缓存(2)

结论

  两种方案都可能出现数据不一致的情况,但在实际情况中,方案2中删除缓存失败的概率要远小于方案1高并发下数据不一致概率的,因此个人推荐先操作数据库再操作缓存

参考:

  1. 缓存更新的套路
  2. 究竟先操作缓存,还是数据库?

相关文章: