思考原因。
程序员在使用缓存时候,一般步骤。
1.查询有没有缓存。 2.情况1,没有缓存,读取数据库,更新缓存,情况2,有缓存返回。 然而这样的逻辑在并发时候会出现脏缓存,就是缓存更新还是旧的。下面就是并发更新缓存的过程图片
这样更新后的缓存还是旧的数据,没有意义。
问题所在,更新缓存只是判断有或者没有,不关注数据是否新旧。
所以在缓存中增加一个时间戳(或者版本号),只有时间戳(或者版本号)大于当前数据才能更新或者缓存为空的时候。
所以得出下面的更新逻辑。
本文共 277 字,大约阅读时间需要 1 分钟。
思考原因。
程序员在使用缓存时候,一般步骤。
1.查询有没有缓存。 2.情况1,没有缓存,读取数据库,更新缓存,情况2,有缓存返回。 然而这样的逻辑在并发时候会出现脏缓存,就是缓存更新还是旧的。下面就是并发更新缓存的过程图片
这样更新后的缓存还是旧的数据,没有意义。
问题所在,更新缓存只是判断有或者没有,不关注数据是否新旧。
所以在缓存中增加一个时间戳(或者版本号),只有时间戳(或者版本号)大于当前数据才能更新或者缓存为空的时候。
所以得出下面的更新逻辑。
转载于:https://my.oschina.net/huotui/blog/848376