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

相关推荐
programhelp_几秒前
Google 2026 New Grad SDE VO 三轮面试详解 | 含Behavioral、Coding、Design
java·服务器·数据库
czhc114007566313 分钟前
数据库520 HALCONAN安装
数据库
阿坤带你走近大数据18 分钟前
Oracle中的OGG介绍
数据库·oracle
Ether IC Verifier20 分钟前
TCP/IP协议握手原理详解——结合以太网连接过程
服务器·网络·数据库·网络协议·tcp/ip
宋浮檀s25 分钟前
SQL注入基础+DVWA搭建
数据库·sql·安全·网络安全
Amarantine、沐风倩✨38 分钟前
Oracle 性能排查:通过 V$LONG_EXEC_SQLS 快速定位慢 SQL
数据库·sql·oracle
倔强的石头1061 小时前
生产环境排坑实录:SQL 标量子查询的“静默杀手”与优化器的智能推演
数据库·sql
jnrjian1 小时前
控制用户alter user 修改密码的两种办法 dbv and triggers
数据库·oracle
米高梅狮子1 小时前
01.mysql的备份与恢复
运维·数据库·mysql·docker·容器·kubernetes·github