在进行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。
如何清理内存碎片?(来自文档)
修正说明:1,实现真正的软件开源。2,安装界面的美化3,真正实现栏目的递归无限极分类。4,后台添加幻灯片图片的管理,包括添加,修改,删除等。5,修正添加新闻的报错信息6,修正网站参数的logo上传问题7,修正产品图片的栏目无限极分类8,修正投票系统的只能单选问题9,添加生成静态页功能10,添加缓存功能特点和优势1. 基于B/S架构,通过本地电脑、局域网、互联网皆可使用,使得企业的管理与业务不受地域
- Redis版本4.0以下:通过重启Redis,可以自动归还所有内存,这种方法简单粗暴。
- Redis版本4.0及以上:可以启用自动内存碎片清理:
127.0.0.1:6379[6]> config set activedefrag yes OK
自动内存清理的相关配置如下:
# 启用主动碎片整理 # 碎片整理总开关 # activedefrag yes当内存碎片达到多少时启动整理
active-defrag-ignore-bytes 100mb
当碎片率达到多少百分比时启动整理
active-defrag-threshold-lower 10
当碎片率小于多少百分比时启动整理
active-defrag-threshold-upper 100
在面对一些复杂的场景时,我们可能希望根据自己的策略进行内存碎片清理,Redis也提供了手动内存碎片清理的命令:
127.0.0.1:6379> memory purge OK
总结:Redis对内存的占有欲很高,总是会留下一些不再使用的内存,这在生产环境中是无法接受的。因此,内存碎片的清理工作至关重要。









