【详解】Redis过期键的删除策略


Redis为什么快?

redis的数据是存储在内存中,内存的读写速度非常快,这也是Redis速度快的主要原因。官方给出的性能可以达到10万/秒。Redis是基于C语言实现的,C语言偏向于底层操作系统,执行速度更快。Redis还使用了单线程的结构,预防了多线程可能产生的竞争问题。

Redis的数据主要存储在内存中,内存是非常珍贵的计算机资源。如何提高内存的使用率非常重要。而Redis的键是有过期时间的,什么时候将过期的键从内存中移除?是立即删除?还是等待很多键都过期了一起删除?还是定期删除?是我们思考的问题。

Redis给出了以下几种策略:

①立即删除(定时删除)

在设置键的过期时间的同时,创建一个定时器timer,当定时器检测到键的过期时间来临的时候,对键进行立即删除的操作。

这种删除策略对内存是比较友好的,能够保证内存中的key一旦过期就立即从内存中删除。但是当过期的键比较多的时候,占用的CPU的时间也比较多,对服务器的吞吐量也会造成影响。的

②惰性删除(redis采用)

当发现键过期的时候不会立即删除,但是当每次从键空间中获取键时,检查该键是否过期。如果过期就删除该键,否则,就返回该键。

这种情况下,如果出现大量过期的键,会占用大量的内存。

③定期删除(redis采用)

每隔一段时间,程序就会对数据库进行一次扫描,删除一定数量的过期的键。实际应用中可以设置每隔多久扫描一次或者一次扫描多久来平衡CPU和内存的资源。

总结:

redis主要使用了惰性删除、定期删除的策略来解决redis中的过期的键删除问题。