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

相关文章

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动