Redis是一种内存级数据库,所有数据均存放在内存中,内存中的数据可以通过TTL指令获取其状态
- XX :具有时效性的数据
- -1 :永久有效的数据
- -2 :已经过期的数据或被删除的数据或未定义的数据
redis中的数据可以设置一个过期时间,比如登录时的验证码,通常都会对其设置一个1—3分钟的有效时间。当数据过了期限后,应该要被删除。但这些数据过期后并不会实时地马上被删除,当这些数据数量累积越来越多,就会占用很多内存,因此在redis底层同时使用了三种策略来删除这些数据。
1.定时删除
创建一个定时器,如果key超时了,由定时器任务立即执行对key的删除操作
优点:节约内存,超时就删除,快速释放不必要内存
缺点:CPU压力大,无论CPU是否负载过高,均占用CPU,会影响redis服务器的响应时间和吞吐量
总结:处理器性能换取存储空间
2.惰性删除
数据到达过期时间,不作处理,等下次访问该数据时
- 如果未过期,返回数据
- 如果过期则删除,返回不存在
内部调用expirelfNeeded()方法判断
优点:节约CPU性能,发现必须删除时才删除
缺点:内存压力很大,会出现长期占用内存的数据
总结:存储空间换取处理器性能
3.定期删除
周期性轮询redis库中的时效性数据,采用随机