删除数据后, redis 内存占用还是很高怎么办?

现象:

reids 做了数据删除,数据量不大,使用 top 命令看,发现还是占用大量内存

原因:

1.redis 底层内存根据内存分配器分配,不会立刻释放

2.redis 释放的内存空间不是连续的,存在碎片

内存碎片怎么形成的?

1、 内因是内存分配策略 申请 20 字节, jemalloc 会分配 32 字节,提前分配

2、外因是 删除不同大小,不同位置的键值对,会出现碎片

怎么定位呢?

info memory 命令 key 查看内存碎片率

used_memory:1073741736

used_memory_human:1024.00

Mused_memory_rss:1997159792

used_memory_rss_human:1.86G

mem fragmentation ratio:1.86

mem fragmentation ratio 指标, 两个指标 used memory rss 和used memory 相除的结果。如果大于 1 小于 1.5 正常,大于 1.5,可以采取措施减少内存碎片

怎么减少呢?

1、最简单粗暴 :重启 redis 实例 ,缺点是导致一部分数据丢失、如果数据量大,aof 日志恢复,时间长,恢复期间无法提供服务

2、4.0 后面,提供新配置自动清理

启用配置

config set activedefrag yes

active-defrag-ignore-bytes 100mb: 表示内存碎片的字节数达到 100MB 时,开始清理;

active-defrag-threshold-lower 10: 表示内存碎片空间占操作系统分配给 Redis 的总空间比例达到 10% 时,开始清理.

active-defrag-cycle-min 25:表示自动清理过程所用 CPU 时间的比例不低于 25%保证清理能正常开展

active-defrag-cycle-max 75: 表示自动清理过程所用 CPU 时间的比例不高于 75%,一旦超过,就停止清理,从而避免在清理时,大量的内存拷贝阻塞 Redis,导致响应延迟升高。

相关推荐
“αβ”1 小时前
MySQL表的操作
linux·网络·数据库·c++·网络协议·mysql·https
p***s911 小时前
Spring数据库原理 之 DataSource
java·数据库·spring
虹科网络安全1 小时前
艾体宝干货 | Redis Java 开发系列#1 从零开始的环境搭建与实践指南
java·数据库·redis
火山引擎开发者社区1 小时前
火山引擎向量数据库 Milvus 版正式商业化:AI 时代的向量检索新标杆
数据库·milvus·火山引擎
神秘的土鸡2 小时前
openEuler 25.09 企业级 MySQL主从复制部署与性能优化实战提升50%
linux·数据库·mysql·性能优化·openeuler
韩立学长2 小时前
基于Springboot课堂教学辅助系统08922bq1(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
菜萝卜子3 小时前
k8s 启动一个redis
redis·容器·kubernetes
goxingman3 小时前
Oracle视图基础
数据库·oracle
serendipity_hky3 小时前
互联网大厂Java面试故事:核心技术栈与场景化业务问题实战解析
java·spring boot·redis·elasticsearch·微服务·消息队列·内容社区