redis实现过期策略
时间: 2023-08-22 16:07:04 浏览: 209
Redis实现过期策略的方式有多种。
引用提到,当我们设置一个key的过期时间时,Redis会将该键带上过期时间存放到一个过期字典中。当key过期后,如果没有触发Redis的删除策略,过期后的数据依然会保存在内存中。这意味着,即使这个key已经过期,我们仍然能够获取到这个key的数据。
除了根据过期时间删除数据外,Redis还有其他的过期策略。具体有以下三种过期策略:
1. 定时删除:在设置key的同时,设置一个定时器,在过期时间到达时删除key。
2. 惰性删除:当某个客户端尝试获取一个已经过期的key时,Redis会立即删除该key。
3. 定期删除:Redis会周期性地随机抽取一部分key,并检查其过期时间。如果过期,则删除。
需要注意的是,Redis并不是实时删除过期的数据,而是根据具体的策略来删除。这也是为了保证Redis的性能和效率。
因此,通过配置过期时间和选择合适的过期策略,可以实现Redis的过期机制,防止数据累加后大量占用存储空间的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *3* [Redis--Redis数据过期策略详解](https://blog.csdn.net/weixin_44074051/article/details/127266404)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *2* [【Redis】Redis 的过期策略以及内存淘汰机制详解](https://blog.csdn.net/weixin_42201180/article/details/129150967)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文