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
随机推荐
- pandas之使用自定义函数
如果想要应用自定义的函数,或者把其他库中的函数应用到 Pandas 对象中,有以下三种方法: 1) 操作整个 DataFrame 的函数:pipe() 2) 操作行或者列的函数:apply() 3) ...
- [Java]排序算法>选择排序>【简单选择排序】(O(n*n)/不稳定/)
1 选择排序 1.1 算法思想 每一趟从待排序的记录中选出关键字最小的记录,按顺序放在已排序的记录序列的最后(or最前面),直到全部排完位置. 1.2 算法特征 属于[选择排序] 简单选择排序 堆排序 ...
- LeeCode 317周赛复盘
T1: 可被3整数的偶数的平均值 思路:数组遍历 被3整数的偶数 \(\Leftrightarrow\) 被6整数的数 public int averageValue(int[] nums) { in ...
- python过滤列表元素
li = [1, 2, 3, 4, 5, 6] def fun(item, num): if item == num: return 1 else: return 0 def fun1(item, n ...
- Linux升级安装GCC
各发行版本Linux中,其自带的gcc安装源版本都比较旧,我所使用CentOS 6系统中,gcc版本只有4.4.7.最近要安装几个软件要求gcc 4.8+,无奈只能手动升级gcc. 1. 下载最新版本 ...
- odoo 开发入门教程系列-继承(Inheritance)
继承(Inheritance) Odoo的一个强大方面是它的模块化.模块专用于业务需求,但模块也可以相互交互.这对于扩展现有模块的功能非常有用.例如,在我们的房地产场景中,我们希望在常规用户视图中直接 ...
- android studio 做登陆界面
先来一个最简单的 AndroidManifest.xml <?xml version="1.0" encoding="utf-8"?> &l ...
- 还不知道怎么 Mock ,用这 6款工具!
以下是几个常用的国外可以mock测试的工具,供参考: MockServer: MockServer 是一个开源的 API mock 测试工具,提供了强大的模拟服务器和 mock 服务功能.MockSe ...
- 【问题解决】RabbitMQ启动出现epmd error for host xx.xx: nxdomain (non-existing domain)
问题描述 [k8s]或[普通容器]或[Linux]部署的RabbitMQ启动时出现了 epmd error for host xx.xx: nxdomain (non-existing domain) ...
- STL大全
排序最速传说--sort 我们都学过一些排序的写法,比如冒泡排序,快速排序之类的东西,举个例子来说吧,这是快速排序的代码: #include<iostream> using namespa ...