彻底说透redis删除策略(牛逼)

redis删除策略:惰性删除,定时删除,定期删除。

惰性删除:每次查询的时候就检测当前key是否过期,如果过期了就直接删除,并返回null值;

  1.  缺点:每次只能删除当前查询的过期key,不查询的key,过期了也不会被删除,导致冗余内存,长期长毛;
  2. 优点:自己捎带干了,不用请单独线程来批量检测删除,导致抢夺cpu;

定期删除:搞一个定时任务,每次去检测是否有过期key,然后批量删除;

  1. 缺点:抢占cpu资源,每次检测范围太大,key越多耗时越久;
  2. 优点:删除全面,不会占用内存;

定期删除:比如每个1小时,定时去检测部分key进行删除,多次迭代,必然干掉所有;

  1. 缺点:不够及时,但是可以调整频率,时长来优化;
  2. 优点:不用粗暴抢夺cpu,也减少内存冗余;

 

总结一句话:定时删除,频率太高,太粗暴,一般高并发设计没人敢用,所以redis用了定期+惰性删除,比较温柔;