通过对线上数据访问时间分布的统计发现,大部分请求只访问最新15分钟或1小时的数据,极少访问超过1天的数据。这使得我们在存储数据时可以优化过期时间,例如将过期时间从2天缩短到1天,从而节省大量 Redis 实例资源,节省内存使用量和成本。Redis 自动清理过期数据的机制可以有效节省资源,而没有自动过期机制时,实现数据清理将非常复杂。自动过期功能不仅简化了操作,还能节省成本,体现了其在缓存系统中的重要性。Redis 在处理请求时,会检查 key 是否过期。在 dictEntry 结构中存储了上次更新时间戳,通过比较当前时间与更新时间戳之间的差值与设定的过期时间,判断 key 是否过期。Redis 提供了懒惰删除功能,即在开启配置项后,会异步处理数据删除任务,防止阻塞主线程。然而,实际实现并非完全异步,而是结合了同步和异步机制,以优化性能。为了解决数据写入后长时间无访问导致的资源占用问题,Redis 实现了定期抽样删除策略。通过单线程执行的核心流程,Redis 无法长时间暂停执行其他工作,因此定期清理时仅做少量操作,以避免长时间阻塞。Redis 数据过期策略简单,但需考虑性能影响。配置过期时间应根据业务需求和数据特性调整,以实现最佳性能和资源利用。本文深入探讨了 Redis 过期数据的实现,包括实时清理、惰性删除和定期抽样删除策略。同时提供了 Redis 中文注释版和源码剖析专栏链接,欢迎关注和学习。如有帮助,欢迎一键三连支持。