内存占用 CPU占用 特征
定时删除 节约内存,无占用 不分时段占用CPU资源,频度高 时间换空间
惰性删除 内存占用严重 延时执行,CPU利用率高 空间换时间
定期删除 内存定期随机清理 每秒花费固定的CPU资源维护内存 随机抽查,重点抽查
在redis中会使用惰性删除和定期删除两种方式。
内存淘汰策略
Redis提供8种数据淘汰策略:
- volatile-lru:从已设置过期时间的数据集中挑选最近最少使⽤的数据淘汰。
- volatile-random:从已设置过期时间的数据集中任意选择数据淘汰。
- allkeys-lru:当内存不⾜以容纳新写⼊数据时,在键空间中,移除最近最少使⽤的 key(常用)
- allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰。
- volatile-ttl:从已设置过期时间的数据集中挑选将要过期的数据淘汰。
- no-eviction:禁⽌驱逐数据,也就是说当内存不⾜以容纳新写⼊数据时,新写⼊操作会报错OOM。
4.0 版本后增加以下两种: - volatile-lfu:从已设置过期时间的数据集中挑选最不经常使⽤的数据淘汰。
- allkeys-lfu:当内存不⾜以容纳新写⼊数据时,在键空间中,移除最不经常使⽤的 key。