Redis中缓存过期、内存被缓存占用要如何处理

网友投稿 318 2023-12-14 13:32:57

Redis中缓存过期、内存被缓存占用要如何处理

这篇文章主要讲解了“Redis中缓存过期、内存被缓存占用要如何处理”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis中缓存过期、内存被缓存占用要如何处理”吧!

已过期的key如何处理?

设置了expire的key缓存过期了,但是服务器的内存还是会被占用,这是因为redis所基于的两种删除策略

redis有两种策略:

(主动)定时删除

定时随机的检查过期的key,如果过期则清理删除。(每秒检查次数在redis.conf中的hz配置)

(被动)惰性删除

当客户端请求一个已经过期的key的时候,那么redis会检查这个key是否过期,如果过期了,则删除,然后返回一个nil。这种策略对cpu比较友好,不会有太多的损耗,但是内存占用会比较高。

所以,虽然key过期了,但是只要没有被redis清理,那么其实内存还是会被占用着的。

那么如果内存被Redis缓存占用慢了咋办?

内存占满了,可以使用硬盘,来保存,但是没意义,因为硬盘没有内存快,会影响redis性能。

所以,当内存占用满了以后,redis提供了一套缓存淘汰机制:MEMORY MANAGEMENT

maxmemory:当内存已使用率到达,则开始清理缓存

noeviction:旧缓存永不过期,新缓存设置不了,返回错误 allkeys-lru:清除最少用的旧缓存,然后保存新的缓存(推荐使用)allkeys-random:在所有的缓存中随机删除(不推荐) volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存 *volatile-random:在那些设置了expire过期时间的缓存中,随机删除缓存 volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的`

感谢各位的阅读,以上就是“Redis中缓存过期、内存被缓存占用要如何处理”的内容了,经过本文的学习后,相信大家对Redis中缓存过期、内存被缓存占用要如何处理这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:数据库连接池技术的原理是什么呢
下一篇:Oracle DBA常用脚本中转换执行shell脚本是怎样的
相关文章