对于redis和数据库数据不一致性的解决方案(读写同时触发)

对比两种方案:

1)先更新数据库,然后删redis。

此方案,如果先更新数据库,然后服务宕机没有删除缓存,那么redis中存的一直是脏数据。

2)先删除redis,然后更新数据库

此方案,如果数据库更新时间比较长,查询操作比较频繁,会导致取到数据库的脏数据。(并发量不高的情况下使用)

3)先删除redis,然后再更新数据库,延迟一会再删redis(并发量较高的情况下使用)

延迟的时间要设置为读数据的时间,也就是更新完数据库到删除redis缓存的时间窗口,再次删除缓存就的原因就是删除因为读造成的脏数据。

posted @ 2024-04-12 17:32  拥有人鱼线的程序猿  阅读(202)  评论(0)    收藏  举报