微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

[ 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:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐