Redis 从入门到精通(十四):内存管理与淘汰策略

系列导读:本篇将深入讲解 Redis 内存管理和淘汰策略,优化内存使用。


文章目录

    • 一、内存管理
      • [1.1 查看内存使用](#1.1 查看内存使用)
      • [1.2 内存配置](#1.2 内存配置)
    • 二、淘汰策略
      • [2.1 策略列表](#2.1 策略列表)
      • [2.2 策略选择](#2.2 策略选择)
    • 三、内存优化
      • [3.1 数据结构优化](#3.1 数据结构优化)
      • [3.2 编码优化](#3.2 编码优化)
      • [3.3 清理内存](#3.3 清理内存)
    • 总结

一、内存管理

1.1 查看内存使用

bash 复制代码
# 查看内存信息
INFO memory

# 关键指标
used_memory: 已使用内存
used_memory_peak: 内存峰值
used_memory_rss: 系统分配内存
mem_fragmentation_ratio: 内存碎片率

1.2 内存配置

conf 复制代码
# redis.conf

# 最大内存限制
maxmemory 2gb

# 内存淘汰策略
maxmemory-policy allkeys-lru

二、淘汰策略

2.1 策略列表

策略 说明
noeviction 不淘汰,内存满时返回错误
allkeys-lru 淘汰最久未使用的key
volatile-lru 淘汰设置了过期时间且最久未使用的key
allkeys-lfu 淘汰使用频率最低的key
volatile-lfu 淘汰设置了过期时间且使用频率最低的key
allkeys-random 随机淘汰key
volatile-random 随机淘汰设置了过期时间的key
volatile-ttl 淘汰即将过期的key

2.2 策略选择

复制代码
缓存场景 → allkeys-lru
热点数据 → allkeys-lfu
有过期时间 → volatile-lru
不能丢数据 → noeviction

三、内存优化

3.1 数据结构优化

bash 复制代码
# 使用Hash替代多个String
# 差:
SET user:1001:name "张三"
SET user:1001:age "25"

# 好:
HMSET user:1001 name "张三" age 25

3.2 编码优化

conf 复制代码
# redis.conf

# Hash优化
hash-max-ziplist-entries 512
hash-max-ziplist-value 64

# List优化
list-max-ziplist-size -2

# Set优化
set-max-intset-entries 512

# ZSet优化
zset-max-ziplist-entries 128
zset-max-ziplist-value 64

3.3 清理内存

bash 复制代码
# 清空数据库
FLUSHDB    # 当前库
FLUSHALL   # 所有库

# 异步清空
FLUSHDB ASYNC
FLUSHALL ASYNC

总结

本文我们学习了:

内存查看 :INFO memory

淘汰策略 :8种策略选择

内存优化:数据结构、编码优化

下篇预告Redis 从入门到精通(十五):安全配置与性能优化


作者 :刘~浪地球
系列 :Redis 从入门到精通(十四)
更新时间:2026-04-08

相关推荐
正经教主2 分钟前
【docker基础】Redis的docker部署
redis·docker·容器
努力成为AK大王2 分钟前
计算机底层核心原理:CPU、总线、缓存与内存深度解析
缓存·内存·cpu
风味蘑菇干5 分钟前
JDBC(数据库连接池&DBUtils)
java·数据库
标书畅畅行6 分钟前
深度解析钛投标AI标书工具:全流程企业级AI投标解决方案,重构投标数字化生产力
大数据·数据库·人工智能
Wait....6 分钟前
MySQL底层知识总结
数据库·mysql
闪电悠米18 分钟前
黑马点评-Redis 消息队列-04_stream_seckill_order
数据库·redis·分布式·缓存·oracle·junit·lua
成为你的宁宁20 分钟前
【基于 Prometheus Operator 实现 K8s 环境下 Redis Cluster 集群监控部署】
redis·kubernetes·prometheus
SeaTunnel23 分钟前
87 个 PR 迭代复盘|Apache SeaTunnel 5 月版本重点更新解读
大数据·数据库·开源·apache·seatunnel
DolphinScheduler社区26 分钟前
实战演示 | 基于 Apache DolphinScheduler 与 Apache SeaTunnel 实现 MySQL 到 Doris 离线定时增量同步
数据库·mysql·开源·apache·海豚调度·大数据工作流调度
bmjIjFNC829 分钟前
Redis分布式锁进第九十一篇
数据库·redis·分布式