redis持久化失败问题(MISCONF Redis is configured to save RDB snapshots, but ......)问题解决

本文主要是介绍redis持久化失败问题(MISCONF Redis is configured to save RDB snapshots, but ......)问题解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天同事反应测试环境业务一直报错,好像是redis持久化出现了问题,并给出了错误信息,让我帮忙看一下,说明明还有2G内存为何还会报错

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.. channel: [id: 0xb07fbbd2, L:/10.4.11.84:43534 - R:ruigecloud-redis/10.4.11.165:6379] command: (EXPIRE), params: [[49, 51, 58, 114, 117, 105, 103, 101, 99, 108, ...], 2592000]

我想内存不够用通常导致持久化失败,但同事告知还有2G内存,我大致明白问题出在哪里了

问题主要有以下几个方面:

1、内存确实没有不够没有合理化分配
解释:Redis在保存数据时为避免主进程假死,会Fork一份主进程,Fork进程完成数据保存到硬盘的操作,若主进程用了4GB,Fork子进程的时候需要额外的4GB,所以内存确实不够了


2、临时处理(日志中有提示“because this instance is configured to report errors during writes if RDB snapshotting fails (stop-writes-on-bgsave-error option).”)

连接redis后运行 config set stop-writes-on-bgsave-error no 命令

提示:仅仅是让程序忽略了这个异常,使得程序能够继续往下运行,但实际上数据还是会存储到硬盘失败!

3、为了看日志方便一定要配置日志路径:

修改配置文件设置logfile

4、低内存环境下,修正后台保存失败问题。

    /etc/sysctl.conf

    末尾添加

   vm.overcommit_memory = 1

sysctl -p

目前为止此问题暂时解决,还需要对Redis的相关配置进行优化!!!

5、配置日志文件、日志级别

loglevel notice

logfile "/data/log/redis-6379.log"

6、做好内存容量规划,设置回收策略

maxmemory 4294967296
maxmemory-policy volatile-lru

允许长期不活跃的数据从Redis丢失

dir 路径
dbfilename dump6379.rdb

7、重启redis

Redis的重启不要kill!!!
127.0.0.1:6379> SHUTDOWN
 

这篇关于redis持久化失败问题(MISCONF Redis is configured to save RDB snapshots, but ......)问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/751680

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

504 Gateway Timeout网关超时的根源及完美解决方法

《504GatewayTimeout网关超时的根源及完美解决方法》在日常开发和运维过程中,504GatewayTimeout错误是常见的网络问题之一,尤其是在使用反向代理(如Nginx)或... 目录引言为什么会出现 504 错误?1. 探索 504 Gateway Timeout 错误的根源 1.1 后端

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据