对比两种方案:
1)先更新数据库,然后删redis。
此方案,如果先更新数据库,然后服务宕机没有删除缓存,那么redis中存的一直是脏数据。
2)先删除redis,然后更新数据库
此方案,如果数据库更新时间比较长,查询操作比较频繁,会导致取到数据库的脏数据。(并发量不高的情况下使用)
3)先删除redis,然后再更新数据库,延迟一会再删redis(并发量较高的情况下使用)
延迟的时间要设置为读数据的时间,也就是更新完数据库到删除redis缓存的时间窗口,再次删除缓存就的原因就是删除因为读造成的脏数据。
标签:不一致性,缓存,删除,数据库,redis,更新 From: https://www.cnblogs.com/zhangzheforever/p/18131766