删除数据后, 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,导致响应延迟升高。

相关推荐
小七-七牛开发者3 小时前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence8 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将11 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3169353811835 天前
Java连接Redis
redis
倔强的石头_5 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence6 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle