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

相关推荐
阿杰学AI15 分钟前
AI核心知识129—大语言模型之 向量数据库(简洁且通俗易懂版)
数据库·人工智能·ai·语言模型·自然语言处理·向量数据库·vector database
SPC的存折16 分钟前
D在 Alpine 容器中手动搭建 Discuz 全攻略(包含镜像一键部署脚本,可直接用)
linux·数据库·mysql·缓存
李兆龙的博客22 分钟前
从一到无穷大 #67 大查询根因分析 - 从 PinSQL 到 RCRank
数据库·时序数据库
AgCl2340 分钟前
MYSQL-6-函数与约束-3/17
android·数据库·mysql
junqiduhang1 小时前
Win11 MySQL 8.0 安装八步走
数据库·mysql
zhangchaoxies1 小时前
golang如何使用SQLx原生SQL查询_golang SQLx原生SQL查询使用方法
jvm·数据库·python
m0_743623921 小时前
mysql如何优化InnoDB缓冲池大小_mysql缓冲池内存调优
jvm·数据库·python
孟意昶1 小时前
Doris专题31-SQL手册-基础元素
大数据·数据库·数据仓库·分布式·sql·知识图谱·doris
m0_617881421 小时前
如何操作 XML 数据_XMLTYPE 与 EXTRACT 函数解析节点
jvm·数据库·python
qq_334563551 小时前
golang如何实现SSTable持久化_golang SSTable持久化实现要点
jvm·数据库·python