redis : Can't save in background: fork: Cannot allocate memory
redis : Can't save in background: fork: Cannot allocate memory
JAVA程序报错信息:
MISCONF Redis is configured to save RDB snapshots, but is currently not able to persist on disk. Commands that may modify the data set are disabled. Please check Redis logs for details about the error
查看redis日志:
:S Dec ::02.069 # Can't save in background: fork: Cannot allocate memory
:S Dec ::08.088 # Can't save in background: fork: Cannot allocate memory
:S Dec ::14.006 # Can't save in background: fork: Cannot allocate memory
:S Dec ::20.021 # Can't save in background: fork: Cannot allocate memory
:S Dec ::26.038 # Can't save in background: fork: Cannot allocate memory
:S Dec ::32.054 # Can't save in background: fork: Cannot allocate memory
:S Dec ::38.067 # Can't save in background: fork: Cannot allocate memory
:S Dec ::44.086 # Can't save in background: fork: Cannot allocate memory
:S Dec ::50.002 # Can't save in background: fork: Cannot allocate memory
:S Dec ::56.017 # Can't save in background: fork: Cannot allocate memory
:S Dec ::02.037 # Can't save in background: fork: Cannot allocate memory
:S Dec ::08.056 # Can't save in background: fork: Cannot allocate memory
:S Dec ::14.073 # Can't save in background: fork: Cannot allocate memory
:S Dec ::20.091 # Can't save in background: fork: Cannot allocate memory
:S Dec ::26.007 # Can't save in background: fork: Cannot allocate memory
数据回写分同步和异步两种方式:
同步回写(SAVE), 主进程直接向磁盘回写数据. 在数据量大的情况下会导致系统假死很长时间
异步回写(BGSAVE), 主进程fork后, 复制自身并通过这个新的进程回写磁盘, 回写结束后新进程自行关闭
由于 BGSAVE 不需要主进程阻塞, 系统也不会假死, 一般会采用 BGSAVE 来实现数据回写.
redis在dump数据的时候会启动fork子进程,由于内存不够,导致无法持久化落盘
redis有个默认的选项:
stop-writes-on-bgsave-error yes
这个选项默认情况下,如果在RDB snapshots持久化过程中出现问题,设置该参数后,Redis是不允许用户进行任何更新操作。
不彻底的解决方式是,将这个选项改为false
stop-writes-on-bgsave-error false
但是这样只是当redis写硬盘快照出错时,可以让用户继续做更新操作,但是写硬盘仍然是失败的
彻底解决方案:直接修改内核参数 vm.overcommit_memory = 1
编辑文件 /etc/sysctl.conf 添加:
vm.overcommit_memory=1
执行sysctl -p使其生效
Linux内核会根据参数vm.overcommit_memory参数的设置决定是否放行。
vm.overcommit_memory = ,直接放行
vm.overcommit_memory = :则比较 此次请求分配的虚拟内存大小和系统当前空闲的物理内存加上swap,决定是否放行。
vm.overcommit_memory = :则会比较进程所有已分配的虚拟内存加上此次请求分配的虚拟内存和系统当前的空闲物理内存加上swap,决定是否放行。
redis : Can't save in background: fork: Cannot allocate memory的更多相关文章
- redis 写磁盘出错 Can’t save in background: fork: Cannot allocate memory  (转)
		
查看 Redis 日志 发现系统在频繁报错: [26641] 18 Dec 04:02:14 * 1 changes in 900 seconds. Saving… [26641] 18 Dec 04 ...
 - Redis报错Can't save in background: fork: Cannot allocate memory及类似问题的处理方法
		
问题的发现及解决过程: 1.Redis主从复制(一主一从)环境在客户端用命令查看主从状态 在slave上输入命令显示如下: 在master上输入命令显示如下: 从显示可以看出主从关系出现问题,然后查看 ...
 - -bash: fork: Cannot allocate memory 问题的处理
		
今天生产机器突然无法登录了,正好有一个用top挂着,但是退出top,执行任何命令都报-bash: fork: Cannot allocate memory,但是查看内存还是有很多空闲,然后在百度上查了 ...
 - -bash: fork: Cannot allocate memory
		
今天遇到服务器无法SSH,VNC操作命令提示fork:cannot allocate memory free查看内存还有(注意,命令可能要多敲几次才会出来) 查看最大进程数 sysctl kernel ...
 - terminal Failed to fork(connot allocate memory)问题处理
		
今天遇到服务器无法SSH,VNC操作命令提示fork:cannot allocate memory free查看内存还有(注意,命令可能要多敲几次才会出来) 查看最大进程数 sysctl kernel ...
 - df卡死和fork:cannot allocate memory报错
		
早上到了公司,发现docker资源池的某一台主机根文件系统写满. 检查后发现该主机/data目录未挂载文件系统,直接放在了根目录下.于是联系业务方将应用迁移,联系主机工程师为/data挂载80G的存储 ...
 - 问题:Linux 输入任何命令都显示 -bash: fork: Cannot allocate memory
		
应该是某个程序吃掉了所有的内存,只能重启
 - redis报Cannot allocate memory错误
		
昨天16:27开始将dp的日志使用ELK处理,当时redis使用内存的量不是很大,100M多点,结果今天早上到了一看xshell被关掉了,赶紧将各服务启动起来,elasticsearch启动没有问题, ...
 - redis写磁盘报错Cannot allocate memory
		
查看 Redis 日志发现系统在频繁报错: [1821] 10 Nov 09:59:04.086 # Can't save in background: fork: Cannot allocate m ...
 
随机推荐
- 在Centos 7.7下用minikube部署单节点kubernetes.
			
centos8 下用yum安装docker-ce会报错,说明docker-ce对centos8支持还不太好.所以在centos7.7下安装 先更新一下系统 yum update 安装 yum工具, ...
 - Android LowMemoryKiller原理分析
			
copy from : http://gityuan.com/2016/09/17/android-lowmemorykiller/ frameworks/base/services/core/jav ...
 - python deepcopy的替代方案
			
from copy import deepcopy import marshal import timeit from multidict import CIMultiDict def test_de ...
 - Django:验证email或者name是否已被注册
			
灵感: http://blog.csdn.net/xxm524/article/details/48369623 使用表单的dajngo的clean()方法实现
 - LoRaWAN协议(一)------架构解析
			
摘自:http://www.cnblogs.com/answerinthewind/p/6200497.html LoRaWAN协议(一)-----架构解析 (1)LoRaWAN分层 LoRaWAN总 ...
 - 刷题55. Jump Game
			
一.题目说明 题目55. Jump Game,给定一组非负数,从第1个元素起,nums[i]表示你当前可以跳跃的最大值,计算能否到达最后一个index.难度是Medium. 二.我的解答 非常惭愧,这 ...
 - C++ 一篇搞懂继承的常见特性
			
微信公众号:「小林coding」 用简洁的方式,分享编程小知识. 继承和派生 01 继承和派生的概念 继承: 在定义一个新的类 B 时,如果该类与某个已有的类 A 相似(指的是 B 拥有 A 的全部特 ...
 - 082、Java数组之数组传递之简化理解
			
01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...
 - redis提供的持久化机制(rdb,aof)
			
Redis提供的持久化机制 Redis是一种面向“key-value”类型数据的分布式NoSQL数据库系统,具有高性能.持久存储.适应高并发应用场景等优势.它虽然起步较晚,但发展却十分迅速. 近日,R ...
 - Jquery实现横向tab切换
			
//需求:鼠标放在不同的导航栏上,下面显示的内容自动切换 //代码如下 <!DOCTYPE html> <html lang="en"> <head& ...