redis中,使用两种内存回收策略
删除过期的Key策略
1、惰性回收,当客户端读取某个Key时,如果当前的Key对应的记录已经过期,则删除当前的这条记录,这个做法的好处:节省CPU成本,不需要维护TTL链表,但是缺点也很明显,不能及时回收已经过期的记录
2、定时回收,每隔一段时间,自定读取一定数量的Key,判断是否已经过期,删除过期的冷数据。
内存超出maxmemory之后,淘汰机制,当Redis使用的内存超出设定的最大内存阈值后,Redis会根据策略,淘汰一部分数据,淘汰策略有六种方式
- noeviction:默认策略,当内存不足以容纳新写入数据时,新写入操作会报错。
- allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的 Key。
- allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个 Key。
- volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的 Key。这种情况一般是把 Redis 既当缓存,又做持久化存储的时候才用。
- volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个 Key。
- volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的 Key 优先移除。