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:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。