Redis是一种内存级数据库,所有数据均存放在内存中,内存中的数据可以通过TTL指令获取其状态:
xx: 具有时效性的数据;
-1:代表永久性数据;
-2:已经过期的数据或已经删除了的数据或未定义的数据;
Redis也不是马上删除数据,而是先进行标记,让其在内存中再多呆一会儿,等到满足一定条件的时候再进行统一删除。
删除策略:
redis开辟了一个存放值的地址和对应过期时间的空间,删除策略相当于是维护这个空间中的东西,上面存的值不变。删除策略主要是为了在内存和cpu占用之间找到一个平衡,因为顾此失彼会造成整个redis的性能下降,甚至引发服务器宕机或者内存泄露。因此在cpu闲的时候把那些过期的数据删除,忙的时候就不占用cpu了。
1.定时删除
创建一个定时器,当key设置有过期时间,且过期时间到达时,由定时器任务立即干掉key值;
优点:节约内存,到点就删除,快速释放掉不必要的内存占用;
缺点:CPU压力很大,无论CPU此时负载量多高,均占用CPU,会影响redis服务器响应时间和指令吞吐量;
总结:用处理器性能换取存储空间(拿时间换空间);
2.惰性删除
数据到达过期时间,不做处理。等下次访问该数据时,如果未过期,则返回数据;如果发现已过期,则删除,返回不存在;
优点:节约CPU性能,发现必须删除的时候才删除