我们都知道Redis的键值对是可以设置过期时间的,那么就会涉及到一个问题,Redis到底是如何做到响应快的同时有能快速地释放掉过期的键值对的呢?不卖关子了,直接说答案,那就是Redis两个策略:定期删除和惰性删除
1.惰性删除
惰性删除就是说Redis不去主动检查,不去删除,只有等到别人要访问这个数据的时候,会先去检查这个数据是不是过期了,如果是过期了,就删除掉这个数据,然后再响应。打个比方,你去超市买东西,结账的时候,老板发现过期了,就不卖给你了;
惰性删除有好处,也有坏处,好处就是不用花时间去大量地检查数据过期了没有,坏处也很大,就是很占内存空间,过期的数据没有及时的释放;
所以还有另外一个策略用来辅助处理这样的情况。
2.定期删除
定期删除就是每隔一段时间就去扫描一部分数据,查看这个写数据过期了没有,如果过期了就删除掉,这样每隔一段时间检查一些,我们都知道Redis是单线程的,就避免了一次性检查所有的数据,导致CUP被占满,而导致的“世界停止”的情况发生;定期检查一部分数据,而且检查的速度够快,这样一来,检查数据对程序的影响就微乎其微了。
为什么要规定删除的时间也很重要?我们都知道Redis是单线程的,程序内部会一直循环检查当前的任务的是什么,然后去执行,执行完一个任务,再去执行下一个任务,如果其中一个任务的时间消耗太多,就会导致后面的任务全都被影响到了,就像堵车一样,为什么会堵车,就是因为一辆车慢了,导致后面的车也慢了,一辆影响一辆,就导致了堵车,所以定期删除定的时间要明确,检查要快。