Redis

关注公众号 jb51net

关闭
首页 > 数据库 > Redis > redis bgsave内存不足异常

Redis BGSAVE 内存不足异常完美解决方案

作者:蒙眼过河

这篇文章详细介绍了Redis BGSAVE内存不足异常的解决方案,包括紧急恢复、根本修复和长期优化三个方面,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,感兴趣的朋友跟随小编一起看看吧

Redis BGSAVE 内存不足异常完整解决方案

一、问题背景与核心报错解析

项目无法正常登录,核心报错日志如下:

Handling error: RedisPipelineException, Pipeline contained one or more invalid commands; 
nested exception is io.lettuce.core.RedisCommandExecutionException: 
MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk. 
Commands that may modify the data set are disabled, because this instance is configured to report errors during writes if RDB snapshotting fails (stop-writes-on-bgsave-error option). 
Please check the Redis logs for details about the RDB error

Redis 侧补充日志:

WARNING overcommit_memory is set to 0! 
Background save may fail under low memory condition. 
To fix this issue add ‘vm.overcommit_memory = 1' to /etc/sysctl.conf 
and then reboot or run the command ‘sysctl vm.overcommit_memory=1' for this to take effect.

错误本质
Redis 执行 BGSAVE(后台生成 RDB 快照)时,需要 fork 子进程来处理持久化,但操作系统因内存分配策略限制,无法为子进程分配足够内存,导致 RDB 持久化失败。而 Redis 默认开启 stop-writes-on-bgsave-error yes,会直接禁用所有写操作,最终引发业务访问异常。

二、分阶段解决方案

1. 紧急恢复(治标):临时解除写操作限制

适用于生产环境需快速恢复业务的场景,无需重启 Redis,但仅解决当前访问问题,未修复根本原因。

# 进入 Redis 客户端
redis-cli
# 临时关闭写操作限制(重启 Redis 后失效)
127.0.0.1:6379> config set stop-writes-on-bgsave-error no
# 验证配置生效
127.0.0.1:6379> config get stop-writes-on-bgsave-error

2. 根本修复(治本):调整系统内存分配策略

修改 vm.overcommit_memory 参数,解决 Redis fork 子进程内存分配失败问题:

# 1. 编辑系统内核参数配置文件
vim /etc/sysctl.conf
# 2. 添加/修改如下配置(建议放在文件末尾)
vm.overcommit_memory=1
# 3. 使配置立即生效(无需重启服务器)
sysctl -p
# 4. 验证配置生效
sysctl vm.overcommit_memory
# 预期输出:vm.overcommit_memory = 1

三、关键参数深度解析

1. vm.overcommit_memory 三种取值对比

取值策略名称核心逻辑适用场景风险点
0启发式策略(默认)分配内存时,对比「申请的虚拟内存」与「空闲物理内存+swap」,不足则拒绝普通服务器、内存充足场景Redis fork 子进程易失败,触发 RDB 持久化报错
1允许内存超分配直接放行所有内存申请,不做校验Redis 服务器、数据库服务器极端内存不足时触发系统 OOM 杀进程
2禁止内存超分配内存分配上限 = 物理内存 × overcommit_ratio(默认50%)+ swap对稳定性要求极高的核心服务器动态创建子进程/申请内存易失败

2. Redis stop-writes-on-bgsave-error 参数

取值行为适用场景
yes(默认)RDB 持久化失败时,禁用所有写操作数据一致性优先的场景(如金融、核心业务)
noRDB 持久化失败时,仍允许写操作可用性优先的场景(临时恢复)

四、扩展优化建议

# 示例:关闭自动 RDB 快照(仅保留手动 BGSAVE)
127.0.0.1:6379> config set save ""
# 开启 AOF 持久化(可靠性更高)
127.0.0.1:6379> config set appendonly yes
127.0.0.1:6379> config set maxmemory 4GB
127.0.0.1:6379> config set maxmemory-policy allkeys-lru

开启 transparent_hugepage 禁用(THP 会增加 fork 耗时):

echo never > /sys/kernel/mm/transparent_hugepage/enabled
# 永久生效:添加到 /etc/rc.local
# 查看最后一次 BGSAVE 状态
127.0.0.1:6379> info persistence
# 关键指标:rdb_last_bgsave_status(成功为 ok)、aof_last_write_status

总结

  1. 紧急恢复:通过 config set stop-writes-on-bgsave-error no 临时解除 Redis 写限制,快速恢复业务访问;
  2. 根本修复:修改系统内核参数 vm.overcommit_memory=1,解决 fork 子进程内存分配失败问题;
  3. 长期优化:结合调整 Redis 持久化策略、限制最大内存、监控持久化状态,避免问题复发。

到此这篇关于Redis BGSAVE 内存不足异常完整解决方案的文章就介绍到这了,更多相关redis bgsave内存不足异常内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文