Redis过期策略

2022-09-05 12:17:58

一 设置了过期时间
定期删除+惰性删除
定期删除: redis默认每隔100ms就随机抽取一些设置了过期时间的key,检查是否过期,如果过期就删除。
考虑性能原因不可能遍历所有的key, 所以实际上是随机抽取一些key来处理.
惰性缓存: 定期删除只能删除一部分过期key, 所以需要惰性删除,其实就类似咱们做被动缓存方式了。
客户端端来请求某个key的时候,redis会检查一下,如果这个KEY过期了,就会删除,不返回任何东西。
所以,两种方式结合,保证过期key的删除,起码保证对客户端来感知来说,绝对是删除了。
二 内存淘汰机制
redis内存不够用了咋办?Redis提供了几种淘汰策略,可以配置。
1. noeviction:当内存不足以容纳新写入数据时,新写入操作会报错,默认策略
redis.windows.conf文件内容
# The default is:
# maxmemory-policy noeviction
2. allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的key(这个是最常用的)
3. allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个key,这个一般没人用
4. volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的key(这个一般不太合适)
5. volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个key
6. volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的key优先移除

  • 作者:sun12141214
  • 原文链接:https://blog.csdn.net/sun12141214/article/details/100602573
    更新时间:2022-09-05 12:17:58