redis的key到了过期时间后,不会立刻被删除,会通过redis自身的删除策略来删除。 1.定时删除策略 在设置key过期时间的同时,创建一个定时器,等key到期了将其删除。 优点:快速删除,节省内存空间 缺点:当cpu高负载时,会给cpu添加额外的压力,同时导致redis服务器的处理效率有所下降 总结:以cpu性能换内存空间 2.惰性删除策略 数据过期后不进行处理,等下次访问该数据时判断该数据是否过期,过期则删除然后返回不存在。 优点:必要时才删除,节约cpu性能 缺点:内存可能会被长期占用 总结:以内存空间换cpu性能 3.定期删除策略 每秒执行10次(读取配置server.hz默认为10)serverCron()方法,serverCron()会调用databasesCron()轮询每个数据库(如db0-db15), databasesCron()会调用activeExpireCycle()对该库中的key进行250ms/10(server.hz)=25ms时长的删除处理。 删除处理过程:随机挑选ACTIVE_EXPIRE_CYCLE_LOOKUPS_PER_LOOP(可配置属性)个key进行检测,若key超时则删除key,若删除的key数量大于检测数量的25%, 则继续循环这个过程,若删除key数量小于等于检测数量的25%或处理时间超过25ms,则结束这个处理过程,然后对下一个数据库进行处理。 优点:每秒消耗一定的cpu资源,消耗不大,内存能得到每秒的定期随机删除。 缺点:定期删除参数要配置得当,配置太极端会发展成跟定时删除或惰性删除差不多的效果。 4.redis默认是同时使用惰性删除和定期删除
redis过期key删除策略
最新推荐文章于 2024-02-05 17:25:52 发布