在进行redis内存清理时,我们通常会关注redis的实时内存使用情况,通过执行info memory命令来查看内存使用情况:
我们常常关注的指标是used_memory和used_memory_rss,它们分别表示Redis数据占用的内存以及Redis向操作系统申请的总内存量。可以看到,这两项之间的差距相当大,我们也可以通过mem_fragmentation_ratio这一指标更直观地观察这种差距。
但是,Redis申请了如此多的内存到底在做什么呢?这确实令人感到疑惑。
我们需要了解以下几个关键词:
used_memory:Redis使用的内存量(以字节为单位)used_memory_rss:操作系统分配给Redis的内存量mem_fragmentation_ratio:操作系统分配给Redis的内存与Redis请求的内存的比率
那么,为什么会产生内存碎片呢?主要有两个原因:
Redis自实现的内存分配器:在Redis中创建新的key-value对时,Redis需要向操作系统申请内存。通常,进程在不再需要申请的内存后会立即释放并归还给操作系统;但Redis不同,它在使用完内存后不会直接归还,而是将其保留在Redis自己实现的内存分配器中管理。这样做的好处是可以实现高性能,但其他应用程序可能就不太高兴了,因为Redis显得有些自私。value的更新:Redis的每个key-value对在初始化时分配的内存大小是最优的。当value发生变化且原来的内存大小不再适用时,就需要重新分配内存。重新分配后,Redis无法正常回收部分内存,这些内存就会一直被占用。
内存碎片率的意义如下(来自文档):
大于1但小于1.5:这是正常值,表示存在一些内存碎片,但可以接受,因为它还能提高性能。大于1.5:内存碎片率较高,需要考虑是否进行内存碎片清理,这应该引起重视。小于1:表示Redis使用的内存不足,已经开始使用swap机制交换内存,即使用硬盘(可以在设置中禁用swap)。这意味着需要考虑扩容Redis。
如何清理内存碎片?(来自文档)
Redis版本4.0以下:通过重启Redis,可以自动归还所有内存,这种方法简单粗暴。Redis版本4.0及以上:可以启用自动内存碎片清理:
127.0.0.1:6379[6]> config set activedefrag yesOK
自动内存清理的相关配置如下:
# 启用主动碎片整理# 碎片整理总开关# activedefrag yes当内存碎片达到多少时启动整理
active-defrag-ignore-bytes 100mb
当碎片率达到多少百分比时启动整理
active-defrag-threshold-lower 10
当碎片率小于多少百分比时启动整理
active-defrag-threshold-upper 100
在面对一些复杂的场景时,我们可能希望根据自己的策略进行内存碎片清理,Redis也提供了手动内存碎片清理的命令:
127.0.0.1:6379> memory purgeOK
总结:Redis对内存的占有欲很高,总是会留下一些不再使用的内存,这在生产环境中是无法接受的。因此,内存碎片的清理工作至关重要。
以上就是Redis内存碎片的产生与清理的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/30528.html
微信扫一扫
支付宝扫一扫