本文主要是介绍[ Redis02篇] Redis过期与内存淘汰策略,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
1.Redis的过期策略
-
惰性删除流程:在进行get或setnx等操作时,先检查key是否过期,若过期,删除key,然后执行相应操作;若没过期,直接执行相应操作。
-
定期删除流程:遍历每个数据库,检查当前库中的指定个数个key(默认是每个库检查20个key,注意相当于该循环执行20次,循环体时下边的描述),如果当前库中没有一个key设置了过期时间,直接执行下一个库的遍历,随机获取一个设置了过期时间的key,检查该key是否过期,如果过期,删除key,判断定期删除操作是否已经达到指定时长,若已经达到,直接退出定期删除。
2.Redis的内存淘汰策略
全局的键空间选择性移除
- no-eviction:禁止驱逐数据,这也是默认策略。当内存不足以容纳新写入数据时,新写入操作会报错
- allkeys-lru:从数据集(server.db[i].dict)中挑选最近最少使用的数据淘汰(这个是最常用的)
- allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰。
- allkeys-lfu:从数据集中挑选使用频率最低的数据淘汰。
设置过期时间的键空间选择性移除
- volatile-lru:从已设置过期时间的数据集(server.db[i].expires)中挑选最近最少使用的数据淘汰
- volatile-ttl:从已设置过期时间的数据集(server.db[i].expires)中挑选将要过期的数据淘汰。
- volatile-random:从已设置过期时间的数据集(server.db[i].expires)中任意选择数据淘汰
- volatile-lfu:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。
这篇关于[ Redis02篇] Redis过期与内存淘汰策略的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!