Redis
设置键的生存时间或过期时间
- 设置以秒为单位的生存时间
- 设置以毫秒为单位的生存时间
特殊:SETEX命令可以在设置一个字符串键的同时为键设置过期时间,其原理和EXPIRE完全一样
- 设置以秒为单位的过期时间
- 设置以毫秒为单位的过期时间
- EXPIREAT 和 PEXPIREAT的过期时间是一个UNIX时间戳
查看键的剩余生存时间
- TTL 一个带有生存时间的键
- PTTL 一个带有过期时间的键
设置过期时间详解
- Redis有四个不同的命令可以用于设置键的生存时间或过期时间
- EXPIRE key ttl : 将键key的生存时间设置为ttl秒
- PEXPIRE key ttl :将键key的生存时间设置为ttl毫秒
- EXPIREAT key timestamp :将键key的过期时间设置为timestamp所指定的秒数时间戳
- PEXPIREAT key timestamp :将键key的过期时间设置为timestamp所指定的毫秒数时间戳
- 在Redis的源码中,EXPIRE、PEXPIRE、EXPIREAT三个命令都是使用PEXPIREAT命令来实现的。
- Redis在读写某个key时,会先调用expireIfNeeded()先判断这个key是否已经过期,如果已过期,就执行删除。
int expireIfNeeded(redisDb *db, robj *key) {
if(!keyIsExpired(db,key)) {
return 0;
}
if(server.masterhost != NULL) return 1;
if(checkClientPauseTimeoutAndReturnIfPaused()) return 1;
server.stat_expiredKeys++;
propagateExpire(db,key,server.lazyfree_lazy_expire);
notifyKeyspaceEvent(NOTIFY_EXPIRED,"expired",key,db->id);
int retval = server.lazyfree_lazy_expire ? dbAsyncDelete(db,key) : dbSyncDelete(db,key);
if(retval) {
signalModifiedKey(NULL,db,key);
}
return retval;
}
- 判断过期原理:Redis在dictEntry中存储了上次更新的时间戳,只需要判断当前时间戳和上次更新时间戳之间的gap是否超过设置的过期时间即可
Redis惰性删除
- 惰性删除就是新开一个线程异步处理数据删除任务。Redis的核心流程是单线程执行,如果某个异步执行特别耗时,会直接影响到Redis的性能,比如删除一个几个G的hash key,针对这种情况,需要新开启一个线程去异步删除,防止阻塞住Redis的主线程,Redis实现惰性删除的时候并不完全是异步。
移除过期时间