1,设置过期时间
expire key time (单位为秒)
setex(String key, int seconds, String value) -- 字符串独有的方式
注意:
- 除了字符串自己有独有的设置过期时间方法外,其他方法都要依靠expire方法来设置时间。
- 如果没有设置时间,那么缓存就是永不过期
- 如果设置了过期时间,之后又想让缓存永不过期,使用 persist key(表示删除key的过期时间)
过期key的判定
- 检查给定key是否存在于过期字典,如果存在,那么取得key的过期时间。
- 检查当前UNIX时间戳是否大于key的过期时间,如果是,keyjin
2,三种过期策略
定时删除:在设置key的过期时间的同时,创建一个定时器(timer),让定时器在key的过期时间来临时,立即执行对key的删除操 作。
优点:对内存友好,保证内存被尽快释放
缺点:对CPU时间最不友好。若过期key过多时,删除过期key会占用很多的CPU时间,(当内存不紧张而CPU紧张时)会对 服务器的响应时间和吞吐量造成影响。
惰性删除:放任key过期不管,但是每次去数据库获取key的时候去检查是否过期,若过期,则删除,返回null.
优点:对CPU时间友好。程序只会在取key的时候对key进行过期检查,这可以保证删除过期key的操作只会在非做不可的情况下 进行(如果此时还不删除的话,我们就会获取到了已经过期的key),并且删除的目标仅限于当前处理的key。
缺点:若大量的过期的key没有再次被访问,从而不会被清除,这样会占用大量内存,而且服务器不会自己去释放它们。
定期删除:每隔一段时间,程序就对数据库进行一次检查,删除里面过期的key。
定时删除占用太多CPU时间,影响服务器的响应时间和吞吐量
惰性删除浪费太多内存,有内存泄漏的危险
定期删除就是前两种策略的折中。
服务器必须根据情况,合理地设置删除操作的执行时长和执行频率。
redis实际实现的是惰性删除和定期删除两种策略。