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