赞
踩
Redis
有三种过期键的删除策略。
三种策略中,第一种和第三种是主动删除,第二种是被动删除。
定时删除策略对内存是友好的,但是对CPU是不友好的。 因为一方面,定时删除可以保证过期的键尽快被删除,释放占用的内存;而另一方面,在过期键较多的情况下,删除操作会占用大量CPU时间,在内存不紧张而CPU紧张的情况下, 将CPU时间用在删除和当前任务无关的键上, 会对服务器的响应时间和吞吐量造成较大的影响。
惰性删除策略对CPU是友好的,但是对内存是不友好的。 因为这种策略不会在删除其他无关的过期键上花费任何CPU时间,但是如果数据库中有非常多的过期键,而这些键又没有被访问到的话, 它们也许永远不会被删除,甚至可以把这种情况看成内存泄漏——无用的垃圾数据占用了大量的内存。
定期删除策略是对前两种删除策略的一种整合和折中。
定期删除的难点是确定删除操作执行的时长和频率。
最后给大家推荐一个LinuxC/C++高级架构系统教程的学习资源与课程,可以帮助你有方向、更细致地学习C/C++后端开发,具体内容请见 https://xxetb.xetslk.com/s/1o04uB
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。