- 使用redis在set key的时候可以给一个expire time,就是过期时间,通过过期时间可以指定这个key可以存活的时间。假设设置了一批key只能存活1个小时的时间,那么1个小时之后redis是怎么对这些key进行删除的?
- 定期删除:redis默认是每隔100ms就随机抽取一些设置了过期时间的key,检查是否过期,如果过期就删除。(这里是随机抽取,因为假如redis存了几十万个key,每隔100ms就遍历所有设置过期时间的key,会给cpu带来很大的负载。)
- 惰性删除:定期删除导致可能很多过期的key到了时间还没有被清理掉,所以就有了惰性删除。加入过期的key在定期删除的时候没有被删除,还停留在内存里,除非你的系统去查一下那个key,才会被redis删除掉,这就是惰性删除。
- 假如定期删除漏掉了很多key,也没有及时去查,也没走惰性删除,就会导致大量的过期的key堆积在内存里,导致redis内存耗尽。怎么解决这个问题呢?redis内存淘汰机制。
Redis设置过期时间
最新推荐文章于 2022-11-21 17:33:03 发布