redis缓存为什么要延时双删

一、只先删缓存

问题:先删缓存,在改库前,其他事务又把旧数据放到缓存里去了。

redis缓存为什么要延时双删_第1张图片

二、只后删缓存

问题:改了库,清理缓存前,有部分事务还是会拿到旧缓存

redis缓存为什么要延时双删_第2张图片

三、普通双删

问题:第一次清空缓存后、更新数据库前:其他事务查询了数据库hang住
第二次清空缓存后:其他事务更新缓存,此时又会把旧数据更新到缓存

redis缓存为什么要延时双删_第3张图片

四、为什么需要延时双删?

在三中,第二次清空缓存之前,多延时一会儿,等B更新缓存结束了,再删除缓存,这样就缓存就不存在了,其他事务查询到的为新缓存。

延时是确保 修改数据库 -> 清空缓存前,其他事务的更改缓存操作已经执行完。
redis缓存为什么要延时双删_第4张图片

五、以上策略还能不能完善

四中说到,采用延时删最后一次缓存,但这其中难免还是会大量的查询到旧缓存数据的。
redis缓存为什么要延时双删_第5张图片
这时候可以通过加锁来解决,一次性不让太多的线程都来请求,另外从图上看,我们可以尽量缩短第一次删除缓存更新数据库的时间差,这样可以使得其他事务第一时间获取到更新数据库后的数据。

可以参考:缓存处理流程

参考redis缓存为什么要延时双删

你可能感兴趣的:(找工作)