redis 的 key 清理,也就是内存回收的时候主要分为:过时删除策略与 内存淘汰策略两部分。redis
删除到达过时时间的 key 。算法
对于每个设置了过时时间的 key 都会建立一个定时器,一旦达到过时时间都会删除。这种方式当即清除过时数据,对内存比较好,dom
可是有缺点是:占用了大量 CPU 的资源去处理过时数据,会影响 redis 的吞吐量 和 响应时间。cdn
当访问一个 key 的时候,才会判断该 key 是否过时,若是过时就删除。该方式能最大限度节省 CPU 的资源。内存
可是对内存不太好,有一种比较极端的状况:出现大量的过时 key 没有被再次访问,由于不会被清除,致使占用了大量的内存。资源
每隔一段时间,扫描redis 中过时key 的字典,并清除部分过时的key。这种方式是前俩种一种折中方法。不一样的状况下,调整定时扫描时间间隔,让CPU 与 内存达到最优。it
redis 内存淘汰策略是指达到maxmemory极限时,使用某种算法来决定来清理哪些数据,以保证新数据存入。io
这种就是从设置了expires过时时间的结果集中选出一部分key淘汰,挑选的算法有:class
volatile-random 从设置了过时时间的结果集中随机挑选key删除。配置
volatile-lru 从设置了过时时间的结果集中挑选上次使用时间距离如今最久的key开始删除
volatile-ttl 从设置了过时时间的结果集中挑选可存活时间最短的key开始删除(也就是从哪些快要过时的key中先删除)
volatile-lfu 从过时时间的结果集中选择使用频率最低的key开始删除(这是Redis 4.0版本后新增的策略)