- 背景
- redis的key配置了过期时间,这个是怎么被删除的?
- redis数据明明过期了,怎么还占用着内存?
- redis就只能用10G,你要是往里面写了20G的数据,会发生什么?淘汰哪些数据?
- redis key过期策略
- redis如何淘汰过期的key:set name zhangsan 3600
- 定期删除:
- 隔一段时间,就随机抽取一些设置了过期时间的key,检查其是否过期,如果过期就删除
- 定期删除可能会导致很多过期key到了时间并没有被删除掉,那咋办呢,所以就是惰性删除
- 惰性删除:
- 概念:当一些客户端尝试访问它时,key会被发现并主动的过期
- 放任键过期不管,但是每次从键空间中获取键时,都检查取得的键是否过期,如果过期的话,就删除该键
- redis服务器实际使用的是惰性删除和定期删除两种策略,通过配合使用这两种删除策略,服务器可以很好的在合理使用CPU时间和避免浪费内存空间之间取得平衡
- 问题
- 如果定期删除漏掉了很多过期的key,然后你也没及时去查,也就没走惰性删除,此时会怎么样?
- 如果大量过期key堆积在内存里,导致redis内存块耗尽了,就需要走内存淘汰机制
- 设计缓存中间件:可以参考redis的key过期淘汰方式和内存不足淘汰方式
posted @
2021-07-28 17:29
Gen2021
阅读(
106)
评论()
编辑
收藏
举报