一:删除策略
1.定期删除 redis默认每隔100ms会随机抽取一些设置了过期的key进行检查其是否过期,如果过期了就删除
2.惰性删除 因定期删除可能导致很多过期key到了时间并没有被删除掉,这就用到了惰性删除,就是你在获取某个key的时候,redis会检查下,这个key是否设置了过期时间,如果设置了而且已经过期了,就会删除而且不会给你返回任何东西,并不是key到时间就被删除掉,而是你查询这个key的时候,redis才会进行检查
二:内存淘汰策略
如果redis的内存占用过多的时候,此时会进行内存淘汰,有如下一些策略:
1.noeviction:当内存放不下新写入的数据时报错,一般没人用
2.allkeys-lru:当内存放不下新写入的数据时,在键空间中,移除最近最少使用的key(这个是最常用的)
3.allkeys-random:当内存放不下新写入的数据时,在键空间中,几乎没人用,随机删除key
4.volatile-lru:当内存放不下新写入的数据时,在设置了过期时间的键空间中,移除最近最少使用的key
5.volatile-random:当内存放不下新写入的数据时,在设置了过期时间的键空间中,随机删除key
6.volatile-ttl:当内存放不下新写入的数据时,在设置了过期时间的键空间中,删除快要过期的key