高并发下的缓存一致性问题

Posted jylsgup

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高并发下的缓存一致性问题相关的知识,希望对你有一定的参考价值。

数据读取的时候:

先查缓存,缓存查不到查数据库,然后把查到的结果放到缓存中。这些都基本上没有争议。

 

但是数据更新的时候:

到底是先更新数据库,还是再更新(or删除)缓存

or 先更新(or删除)缓存,再更新数据库。

一直存在很大的争议。几种实现方式都会出现数据一致性问题。

 

我就说说目前我们系统是怎么做的:

0、先确认缓存命中率。不要动不动就上缓存,有些缓存命中率根本毫无意义,比如涉及到和账户相关的资产、订单等信息,就算放入缓存中,只有用户自己会去查自己的信息,命中率极低。

     一般是把与账户无关,且查询量较大的放入缓存中。     

1、缓存设置过期时间,保证最终一致性。

2、先更新数据库,再删除缓存。

可能会出现更新数据库后,删除缓存失败,导致缓存是旧数据,数据库是新数据,出现不一致性。
但是这种概率非常低。
而且删除缓存失败后,我们也可以做一些处理。
 
为什么是删除缓存,而不是更新缓存。
因为缓存不一定直接是数据库中的内容,有可能是多个字段计算出来的,如果每次更新都去写缓存,会导致性能消耗。
 
为什么不是先删除缓存,再更新数据库。
因为先删除缓存,如果在更新操作还没commit的时候,另外一个线程进来读取数据,缓存查不到,查数据库并放入缓存。然后第一个更新操作commit了。
导致缓存是旧数据,而数据库是新数据。且不会像前面提到的删除缓存失败那样方便做处理。
 
 
如果业务要求强一致性,则尽可能不用缓存。

以上是关于高并发下的缓存一致性问题的主要内容,如果未能解决你的问题,请参考以下文章

高并发下如何保证数据库和缓存双写一致性?

缓存击穿

如何保障缓存和数据库的一致性(超详细案例)

如何保障缓存和数据库的一致性(超详细案例)

如何保障缓存和数据库的一致性(超详细案例)

如何保障缓存和数据库的一致性(超详细案例)