Redis的过期删除策略

一个Redis中可能同时存在大量的key,这些key中可能大部分都有过期时间,那么这个时候Redis怎么知道哪些key已经过期哪些key还没有过期呢?这里就涉及到了Redis的过期删除策略

Redis的过期删除策略是指在键(key)上设置了过期时间后,Redis在某个条件触发的时候会自动删除过期的键。Redis提供了两种过期删除的策略,一种是惰性删除,另一种是定期删除

一、惰性删除策略

惰性删除策略(懒汉方式),当Redis中访问某个键的时候,会首先检查这个键是不是过期而不是立即使用,如果这个键已经过期了那么就删除。(这就好比你买了一个零食,突然发现它过期不能吃是一个道理)

二、定期删除策略

有了惰性删除策略之后为什么还要有定期删除呢?这是因为每当我用的时候才去检查是否过期,这样就会造成一部分过期的键漏掉(零食店每次卖零食都要等卖给顾客的时候被顾客检查出过期,那久而久之肯定就不会有人去买了)

那为什么是定期删除呢?Redis是在内存中存储数据的,如果Redis将所有的key都遍历一遍就会造成Redis的效率大大降低(零食店老板不可能将所有商品都抽出来,这样太浪费时间了,只能定期检查一部分是否过期),所以就有了这种定期删除的策略。

定期删除策略指的是:Redis会定期的随机抽取一部分设置过过期时间的键(不全部遍历,只抽取部分),检查他们是否过期,如果过期则删除。

三、注意

当然如果只是使用这两种定期删除的策略,肯定还是会有部分过期的键没有被检查到,那这个时候越存越多不就会让内存崩溃吗?当然不是这样的,Redis中除了这两种方式处理过期的键,还引入了内存淘汰机制来处理过期的键(后续再说)。这样就保证了内存不会被占满的问题

你可能感兴趣的:(Redis,redis,数据库,缓存)