redis集群报错:MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk.
之前在x86架构的服务器部署redis集群,未遇到题中问题;然而在ARM架构的服务器部署redis集群,第一次遇到如此问题。虽然问题已经解决,但不清楚问题的具体原因,在此做个记录。
性能测试过程中,通过pinpoint捕捉到如下报错:
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-write...(618)
这个错误通常表示Redis配置了保存RDB快照,但当前无法将快照持久化到磁盘上。
解决办法如下:
方法一:通过命令行修改
redis-cli登入redis,输入命令:config set stop-writes-on-bgsave-error no
127.0.0.1:6379> config set stop-writes-on-bgsave-error no
方法二:通过配置文件修改
修改redis.conf配置文件,将stop-writes-on-bgsave-error 的参数yes改为no。随后重启redis服务。
230 # However if you have setup your proper monitoring of the Redis server
231 # and persistence, you may want to disable this feature so that Redis will
232 # continue to work as usual even if there are problems with disk,
233 # permissions, and so forth.
234 stop-writes-on-bgsave-error yes
问题原因分析:
① 就上述【方法二】中的redis配置文件信息,咨询chatGPT,给出如下回复:

230号行:然而,如果你已经正确设置了对Redis服务器的监控和持久化,你可能希望禁用这个特性,以便即使出现磁盘、权限等问题,Redis仍然可以正常工作。 231号行:该行是一个注释,提醒用户可以禁用Redis报告错误的功能,因为在正确设置了监控和持久化的情况下,Redis可以继续正常工作,即使磁盘或权限等存在问题。 232号行:注释说明了禁用此功能后的效果,即Redis将继续以往的工作方式运行,即使在磁盘、权限等方面存在问题。 233号行:该行是一个注释,提醒用户可能还有其他类似的问题。 234号行:stop-writes-on-bgsave-error yes表示当RDB快照失败时,停止写入命令。这意味着如果RDB快照操作失败,Redis会禁止执行可能修改数据集的命令。
② 进一步咨询chatGPT,什么情况下会出现redis RDB快照失败的情况?继续给出如下回复:

Redis RDB快照可能会失败的几种情况包括: 磁盘空间不足:当Redis尝试将RDB快照写入磁盘时,如果磁盘空间不足以容纳快照文件,就会导致快照失败。 权限问题:如果Redis进程没有足够的权限将RDB快照文件写入指定的目录,就会导致快照失败。确保Redis进程具有正确的权限来访问和写入目标目录。 磁盘故障:如果磁盘发生错误或损坏,可能会导致RDB快照无法成功写入磁盘,从而导致快照失败。 系统错误或中断:在执行RDB快照过程中,如果发生了系统错误或中断(如服务器崩溃、断电等),可能会导致快照失败。 内存不足:如果Redis实例的内存使用达到上限,可能会导致RDB快照失败。在执行快照之前,确保Redis实例有足够的可用内存来完成快照操作。 其他配置问题:一些配置问题,如错误的保存频率、目录配置错误等,也可能导致RDB快照失败。 需要注意的是,RDB快照失败不会导致数据丢失,因为Redis仍然可以继续运行并将数据保存在内存中。但是,如果持久化是关键需求,建议及时解决RDB快照失败的问题以确保数据的持久性和可靠性。
就此推测,应该是由于上述的某原因导致redis RDB快照失败,然后必须得将stop-writes-on-bgsave-error 的参数值配置为no才行。进一步推理:如果解决了上述导致redis RDB快照失败的问题,即使将参数修改回默认的yes,重启redis服务,问题也将不复存在。
redis集群报错:MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk.的更多相关文章
- Redis常见报错之 Redis::CommandError (MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk)
在Redis运行过程中,报错信息如下: Redis::CommandError (MISCONF Redis is configured to save RDB snapshots, but it i ...
- 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 e
早上来到公司,线上的项目报错: Error in execution; nested exception is io.lettuce.core.RedisCommandExecutionExcepti ...
- redis异常信息:MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk.。。。。
redis.exceptions.ResponseError: MISCONF Redis is configured to save RDB snapshots, but it is current ...
- 解决MISCONF Redis is configured to save RDB snapshots, but it is currently not able to persist on disk.问题
突然发现昨天刚搭建的websocket不能连接了,提示: MISCONF Redis is configured to save RDB snapshots, but it is currently ...
- redis集群报错
写入redis集群报错:(error) MOVED 6918 解决方法:redis-cli -c -p 7001 -h 10.0.0.104
- redis集群报错:(error) CLUSTERDOWN Hash slot not served
百度上坑太多,如果你遇到搭建redis集群的时候出现这个错误在百度上找到解决办法基本上都是坑. 首先集群搭建完成后,你肯定去登陆redis进行测试 1.redis01/redis-cli -h &qu ...
- redis集群报错:(error) CLUSTERDOWN The cluster is down
更换了电脑,把原来的电脑上的虚拟机复制到了新电脑上,启动虚拟机上的centos系统,然后启动redis集群(redis5版本),发现集群可以启动,redis进程也有,但是连接集群中的任意节点就报错,如 ...
- maven项目中使用redis集群报错: java.lang.NumberFormatException: For input string: "7001@17001"
解决:由于redis集群的采用的版本是2.7的,在maven的pom.xml中将jedis的版本改成2.9的就可以了
- maven项目中使用redis集群报错: java.lang.NumberFormatException: For input string: "7006@17006"
Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [redis.client ...
- redis集群报错:(error) MOVED 11469 192.168.163.249:7002
应该是你没有启动集群模式(即缺少了那个"-c"): redis-cli -c -h yourhost -p yourpost
随机推荐
- 【前端黑魔法】浏览器打开任意可执行exe文件方法
思路:通过注册表注册自定义URL协议执行bat脚本,将文件路径作为参数传入 环境:win10 前置问题与条件 问题1:可以从浏览器直接打开可执行文件吗? 答:不能.其实可以通过 ActiveXObje ...
- pandas之面属行统计
描述统计学(descriptive statistics)是一门统计学领域的学科,主要研究如何取得反映客观现象的数据,并以图表形式对所搜集的数据进行处理和显示,最终对数据的规律.特征做出综合性的描述分 ...
- Kubernetes客户端认证——基于CA证书的双向认证方式
1.Kubernetes 认证方式 Kubernetes集群的访问权限控制由API Server负责,API Server的访问权限控制由身份验证(Authentication).授权(Authori ...
- Python程序笔记20230304
抛硬币实验 random 模块 import random random.randint(a, b) 返回一个随机整数 N,范围是:a <= N <= b random.choice(&q ...
- Docker 配置阿里云或腾讯云镜像加速
1.新建 /etc/docker/daemon.json 文件,并写入以下内容: 阿里云按下面配置 sudo tee /etc/docker/daemon.json <<-'EOF' { ...
- Django笔记二十四之数据库函数之比较和转换函数
本文首发于公众号:Hunter后端 原文链接:Django笔记二十四之数据库函数之比较和转换函数 这一篇笔记开始介绍几种数据库函数,以下是几种函数及其作用 Cast 转换类型 Coalesce 优先取 ...
- DeFi-W3
Gas Fee 每一笔交易都会产生Gas Fee. GWei ETH的最小单位 出价(gas fee)的高低会影响交易上联的速度,越快就价格越高. gas fee是跟具体的计算量有关的 Smart c ...
- ASP.NET Core设置URLs的几种方法,完美解决.NET 6项目局域网IP地址远程无法访问的问题
近期在dotnet项目中遇到这样的问题:.net6 运行以后无法通过局域网IP地址远程访问.后查阅官方文档.整理出解决问题的五种方式方法,通过新建一个新的WebApi项目演示如下: 说明 操作系统:U ...
- Weblogic11g安装部署-winserver篇
目录 一.安装weblogic11g 1.1找到下载好的weblogic11g 1.2打开安装程序wls1033_oepe111150_win32.exe,并完成初始化如下图 1.3点击下一步并选择安 ...
- Django, urls的参数name的demo
Django的路由变化 遇到需要修改路由的需求,特别记录一下 项目开始 django-admin startproject sandboxOA. # 外部文件夹可以改变名字, '.'的意思是上一级不需 ...