欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > Redis的Key的过期策略

Redis的Key的过期策略

2025/4/17 0:29:05 来源:https://blog.csdn.net/daima2/article/details/147198497  浏览:    关键词:Redis的Key的过期策略

我们都知道Redis的键值对是可以设置过期时间的,那么就会涉及到一个问题,Redis到底是如何做到响应快的同时有能快速地释放掉过期的键值对的呢?不卖关子了,直接说答案,那就是Redis两个策略:定期删除和惰性删除

1.惰性删除

        惰性删除就是说Redis不去主动检查,不去删除,只有等到别人要访问这个数据的时候,会先去检查这个数据是不是过期了,如果是过期了,就删除掉这个数据,然后再响应。打个比方,你去超市买东西,结账的时候,老板发现过期了,就不卖给你了;

        惰性删除有好处,也有坏处,好处就是不用花时间去大量地检查数据过期了没有,坏处也很大,就是很占内存空间,过期的数据没有及时的释放;

        所以还有另外一个策略用来辅助处理这样的情况。

2.定期删除

        定期删除就是每隔一段时间就去扫描一部分数据,查看这个写数据过期了没有,如果过期了就删除掉,这样每隔一段时间检查一些,我们都知道Redis是单线程的,就避免了一次性检查所有的数据,导致CUP被占满,而导致的“世界停止”的情况发生;定期检查一部分数据,而且检查的速度够快,这样一来,检查数据对程序的影响就微乎其微了。

        为什么要规定删除的时间也很重要?我们都知道Redis是单线程的,程序内部会一直循环检查当前的任务的是什么,然后去执行,执行完一个任务,再去执行下一个任务,如果其中一个任务的时间消耗太多,就会导致后面的任务全都被影响到了,就像堵车一样,为什么会堵车,就是因为一辆车慢了,导致后面的车也慢了,一辆影响一辆,就导致了堵车,所以定期删除定的时间要明确,检查要快。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com