redis过期键未释放原因分析
背景:
1、redis版本5.0;
2、32G的redis云服务器,内存持续上涨,过期键占用内存一直未释放。内存使用如下图:
近期redis操作:把2000万永不过期键,随机分配7-20天的过期时间。
优化过程:
1、对阿里云“离线全量key分析”持续观察几天;
2、发现过期键的内存一直没有释放,从2G涨到5G;
3、分析过期键内存不释放原因;
4、调整redis的hz参数,从10调30,发现没有变化;
5、分析redis源码。
6、结论:redis内存不释放原因:近期把2000万个键设置过期时间,导致垃圾回收命中率达不到25%,不会重复轮循过期键。(源码文件:expire.c,activeExpireCycle函数)。
hz说明
7、最终处理方式:无需任何操作,随着过期键增多命中率提高,内存最终会释放(想加快把“hz”参数设置越大越快,但是会消耗更多CPU资源,可参数阿里云文档)。
本作品采用《CC 协议》,转载必须注明作者和本文链接
难怪我的内存看着一段时间不停增加,导致内程不足杀进程
Redis 可以调整过期策略。
肯定是你选的过期策略的问题