请教大家一个 redis 内存占用的问题

2016-12-04 14:49:37 +08:00
 endice

我用 del 命令删除了 redis 里五分之一的数据,可是 redis 的内存占用并没有下来, rdb 文件可以看到变小了的,只有 redis 重启才会降低内存占用,可是 redis 不能重启的。这是什么原因呢?我删数据就是为了减少内存占用,而且不能重启的,有其他的解决办法吗?

5763 次点击
所在节点    Redis
15 条回复
erenno1
2016-12-04 15:01:26 +08:00
搞个 slave 同步以下,切换
mengskysama
2016-12-04 22:59:59 +08:00
https://redis.io/topics/memory-optimization
Memory allocation 章节有说的很清楚了, redis 详解里面也有说
owt5008137
2016-12-05 00:06:52 +08:00
如果立刻降下来,你想想要花多少 CPU 做内存碎片整理和内存紧缩呀。那得暂停服务多久呀?
所以正常的设计都不会让它立刻降下来
endice
2016-12-05 00:10:03 +08:00
@owt5008137 那就是说会慢慢降下来?还是说不会降了,只是后来的分配内存就使用那些释放的?
endice
2016-12-05 00:11:23 +08:00
@mengskysama 我看那个章节里有说会重用这些内存,可是我删除数据后 redis 的内存占用还是一直在增。
endice
2016-12-05 00:12:11 +08:00
@mengskysama 是说尽可能,那我关注下是不是内存增加的速度比以往要慢了
mengskysama
2016-12-05 00:24:25 +08:00
@endice 用 info 命令监控一下
endice
2016-12-05 00:41:09 +08:00
@mengskysama 我听我同事说他 redis 内存占了 6G ,可是实际使用的只有 3G ,这要怎么解决?
fyibmsd
2016-12-05 08:55:35 +08:00
加内存
owt5008137
2016-12-05 09:08:55 +08:00
@mengskysama 贴的文档里说了根据 malloc 的实现不同而不同。你可以去看一下 jemalloc 的设计模型。具体和你的 redis 使用的情况有关,主要是内存碎片的分布和操作顺序。
简单地说就是,不一定会还给操作系统,即便还也不一定什么时候还多少给操作系统
enenaaa
2016-12-05 09:47:23 +08:00
@endice 用 info memory 命令查看内存占用细节。
snopy
2016-12-05 10:12:39 +08:00
之前搞过一个小脚本监控 redis 内存,超过某个值( 5G )就手动重启,一般能管 5 天左右,公司 storm 集群中的 redis 可以随意重启
KKKKKK
2016-12-05 10:36:10 +08:00
@snopy redis 重启之后数据怎么办??
harryhao
2016-12-05 11:32:21 +08:00
数据无效并不是马上清除的
goldenpangolin
2017-01-11 18:55:15 +08:00
@KKKKKK 大概是当缓存在用
实际有数据库存盘吧

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/325182

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX