标签:过期 db Redis server Redis02 内存 key 淘汰 数据
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:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。
标签:过期,db,Redis,server,Redis02,内存,key,淘汰,数据 来源: https://blog.csdn.net/qq_38011415/article/details/121567472
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。