bgsave出错原因分析
2017-02-16 19:17
127 查看
redis bgsave出错
权限问题 没有遇到过dump.rdb所在的文件夹用户没有权限,导致dump.rdb文件停止更新,此时修改redis数据时会报错,原因是默认配置 stop-writes-on-bgsave-error yes当bgsave出错时数据将不能修改如下操作后可以更新数据: config set stop-writes-on-bgsave-error nodump.rdb文件也恢复更新
redis的内存占用较大时,在上述操作后dump.rdb仍然会停止更新,并且slave服务器也不能同步,原因是操作系统的vm.overcommit_memory配置,如下操作dump.rdb文件恢复更新,slave数据也可以同步。
echo 1 > /proc/sys/vm/overcommit_memory
使用root用户启动没有上述问题
vm.overcommit_memory配置说明
vm.overcommit_memory 表示内核在分配内存时候做检查的方式。这个变量可以取到0,1,2三个值。对取不同的值时的处理方式都定义在内核源码 mm/mmap.c 的 __vm_enough4000
_memory 函数中。
取 1 的时候 : 此时宏为 OVERCOMMIT_ALWAYS,函数直接 return 0,分配成功。
取 2 的时候: 此时宏为 OVERCOMMIT_NEVER,内核计算:内存总量×vm.overcommit_ratio/100+SWAP 的总量,如果申请空间超过此数值,则分配失败。vm.overcommit_ratio 的默认值为50。
取 0 的时候: 此时宏为 OVERCOMMIT_GUESS,内核计算:NR_FILE_PAGES 总量+SWAP总量+slab中可以释放的内存总量,如果申请空间超过此数值,则将此数值与空闲内存总量减掉 totalreserve_pages(?) 的总量相加。如果申请空间依然超过此数值,则分配失败。
以上为粗略描述,在实际计算时,如果非root进程,则在计算时候会保留3%的空间,而root进程则没有该限制。详细过程可看源码。
参考连接
相关文章推荐
- Redis:BGSAVE出错原因分析
- .net2.0中SqlBulkCopy批量复制数据出错原因分析!
- wince5.0下编译嵌入式操作系统sysgen阶段出错原因分析
- cellForRowAtIndexPath出错原因分析
- 【总结】在两个Activity之间进行跳转时出错原因分析(一)——findViewById位置不当导致
- php session_start()出错原因分析及解决办法
- Asp出错信息列表—原因与分析
- 【Arcgis for android】程序运行出错原因分析及解决(超详细)
- wamp环境出错,apache启动不了的原因分析
- Android上UMENG渠道打包工具出错原因分析
- 【总结】在两个Activity之间进行跳转时出错原因分析(二)——在AndroidManifest.xml未声明导致
- 转 如何根据乱码现象来分析转码出错的原因
- Python中Socket服务器打开端口出错原因分析 .
- 关于恢复出厂后出错的原因分析及解决与预防的方法
- scrollToRowAtIndexPath出错原因分析
- Eclipse tomcat 建立工程时,class的头部出错原因分析
- Linq To Entity 中删除出错的原因分析
- x264在VC环境编译出错原因分析(转载) .
- php session_start()出错原因分析及解决方法
- Python中Socket服务器打开端口出错原因分析