it编程 > 数据库 > Redis

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

17人参与 2026-03-09 Redis

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内存不足异常内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

Redis主从复制搭建、哨兵搭建、集群搭建全过程

03-08

redis 8.2.1 的密码修改使用密文的操作方案

03-10

Red Hat6.4环境下搭建FTP服务器的详细步骤

03-10

Redis锁与DB锁的使用与区别小结

03-06

Redis中大key处理的问题解决

03-06

redis批量删除namespace下的数据实现

03-11

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论