Redis 过期策略

redis设置过期时间

expire key time(以秒为单位)–这是最常用的方式
setex(String key, int seconds, String value)–字符串独有的方式

除了字符串自己独有设置过期时间的方法外,其他方法都需要依靠expire方法来设置时间,如果没有设置时间,那缓存就是永不过期。

三种过期策略

1.定时删除

在设置key的过期时间时,为key创建一个定时器,让定时器在key的过期时间来临时,对key进行删除。

优点:内存会被尽快释放,对内存友好。

缺点:若过期key很多,删除这些key会占用很多的CPU时间,对CPU不友好,若为每一个设置过期时间的key创建一个定时器(产生大量定时器),性能影响严重。

2.惰性删除

每次通过取key值的时候检查是否过期,若过期,则删除,返回null。

优点:删除操作只发生在通过key取值时发生,而且只删除当前key,对CPU友好。

缺点:若大量的key在超出超时时间后,很久一段时间内,都没有被获取过,那么可能发生内存泄露(无用的垃圾占用了大量的内存)

3.定期删除

每隔一段时间执行一次轮询删除过期key

优点:通过限制删除操作的时长和频率,一定程度上减少删除操作对CPU的占用和降低惰性删除对内存占用的缺点。

缺点:在内存友好方面,不如定时删除,在CPU时间友好方面,不如惰性删除。

难点:如何设置时长和频率。

memcached与redis

memcached只使用了惰性策略,redis使用了惰性和定期策略。

你可能感兴趣的:(缓存系统)