缓存策略:Cache aside
(1)读请求
应用首先判断缓存中是否有数据,缓存命中的话,直接返回数据;缓存没有命中的话,从数据库中查询出数据,然后会写到缓存中,再返回数据。
(2)写请求
首先更新数据库,然后从缓存中删除数据。
问题:
为什么不在写请求的时候,直接回写数据?
并发场景中,可能会发现数据不一致的情况。比如写请求情况下,先更新数据库,再更新缓存,请求1先写数据18到数据库,还未更新缓存,此时请求2写数据20到数据库,更新缓存数据为20,这个时候请求1 再更新缓存数据,这样就会导致数据库数据是20,缓存数据是18的 数据不一致的情况。