不一致问题:
- 先修改数据库,再更新缓存:
- 缺点:如果在修改数据库之后更新缓存之前出现问题,出现数据不一致
- 解决方案:先删除缓存,再修改数据库
- 先删除缓存,再修改数据库:
- 缺点:如果在删除缓存之后修改数据库之前,出现另一个线程去读缓存发现缓存为空,又从数据库拉取还没被修改的旧数据到缓存,导致数据不一致(注:只有在对一个数据在并发的进行读写的时候,才可能会出现这种问题。其实如果说你的并发量很低的话,特别是读并发很低,每天访问量就 1 万次,那么很少的情况下,会出现刚才描述的那种不一致的场景)
- 解决方案:在修改数据的时候,在JVM内部队列中放入这条数据的唯一标识,当另一个请求过来发现缓存中数据为空时先不去数据库拉取数据,而是把这个请求也放到内部队列中,等前面的修改操作执行完再去拉取数据(注:一个队列中,其实多个更新缓存请求串在一起是没意义的,因此可以做过滤,如果发现队列中已经有一个更新缓存的请求了,那么就不用再放个更新请求操作进去了,直接等待前面的更新操作请求完成即可。)
参考: