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

相关推荐
笨蛋不要掉眼泪几秒前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap
Coder_Boy_15 分钟前
基于SpringAI的在线考试系统-整体架构优化设计方案
java·数据库·人工智能·spring boot·架构·ddd
fen_fen9 小时前
Oracle建表语句示例
数据库·oracle
砚边数影10 小时前
数据可视化入门:Matplotlib 基础语法与折线图绘制
数据库·信息可视化·matplotlib·数据可视化·kingbase·数据库平替用金仓·金仓数据库
orange_tt11 小时前
Djiango配置Celery
数据库·sqlite
云小逸11 小时前
【nmap源码学习】 Nmap网络扫描工具深度解析:从基础参数到核心扫描逻辑
网络·数据库·学习
肉包_51111 小时前
两个数据库互锁,用全局变量互锁会偶发软件卡死
开发语言·数据库·c++
霖霖总总12 小时前
[小技巧64]深入解析 MySQL InnoDB 的 Checkpoint 机制:原理、类型与调优
数据库·mysql
ALex_zry12 小时前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
此刻你13 小时前
常用的 SQL 语句
数据库·sql·oracle