开端只是生存一个引文,不过有时候也值得大家去思考一番,还毁会办下面进入正题。生存 下面分几个部分讲啦,还毁会办先来回顾一下Redis键的生存生存时间,过期时间的还毁会办设置;然后会讲到过期键删除策略;然后会聊其他功能对过期键的处理。 键过期时间设置通过Expire命令或者Pexpire命令,客户端可以以毫秒级的还毁会办精度为数据库中的某个键设置生存时间,一段时间后Redis服务器会删除生存时间为0的生存键。下面我们看一下Redis键的还毁会办过期时间设置,以及查询键剩余寿命。生存 EXPIRE key 5 #设置一个键的还毁会办过期时间 单位秒 EXPIREAT KEY 1660753861 #设置过期时间某个时间戳过期(UNIX时间戳)单位秒 PEXPIRE key 33 #设置一个键的过期时间 单位毫秒 PEXPIREAT key 1660839534000 #设置过期时间某个时间戳过期(UNIX时间戳)单位毫秒 TTL key # 返回键的剩余过期时长,单位秒 Redis中的还毁会办这些键的过期时间如何保存 Redis中维护了一个过期字典。其数据结构中,生存字典的键是一个指针,指向某个数据库键,云服务器提供商而字典的键值则是一个long类型的整数,表示一个毫秒精度的UNIX时间戳。 其实上面几种设置键过期时间的命令相当于最后都是调用 PEXPIREAT 这个命令。 Redis中判断键是否过期会使用以下的方法 常见删除策略有三种:定时删除、惰性删除、定期删除 3.2.1定时删除 定时删除是在设置键的过期时间时,设置一个定时器,定时器会在键的过期时间到来时立即删除键 3.2.2惰性删除 惰性删除只会在程序需要使用键时,才会对当前键进行过期检查,而不会去删除其他的过期键。 惰性删除执行步骤如下: 3.2.3定期删除 定期删除是每隔一段时间执行一次过期键删除操作,可以通过限制删除的操作执行的时长和频率来减少CPU资源占用。同时定期删除策略不会导致过期键过多的堆积,造成大量内存泄漏。 定期删除策略有两个点比较重要,高防服务器执行时长和执行频率。需要两者结合才能达到最优的效果。 定期删除步骤: 定期任务执行频率: 为了定期检测资源和服务状态并根据预定策略执行相应的操作,Redis会调用内部函数来执行多种后台任务。 其执行频率由hz参数指定,默认为10,即每秒执行10次。 这个值可以设置1-500,但是官方建议设置100以下,设置过大会造成CPU资源占用过大。基本上只用默认值就能满足大部分需求。 Redis数据保存有AOF和RDB两种功能。对于过期键的处理也不相同。 RDB持久化对过期键的处理: 主服务器模式。载入RDB文件时,会对key的过期时间进行检查,过期键会被忽略,不会加载到Redis中 从服务器模式。所有数据key都会加载到Redis中 AOF持久化对过期键的处理: 当Redis服务器处于复制模式时对过期键的处理: Redis的过期策略采用惰性删除和定期删除两种组合方式,其中惰性删除保证过期键一点过不会被使用,定期删除可以保证过期数据得到释放,优化资源占用率。1.前言
2.键的生存生存时间
3.键的过期删除策略
3.1 如何判定键过期4.其他功能对过期键的处理
总结