Redis"MISCONF Redis is configured to save RDB snapshots,but is currently not able to persist on disk

查看redis日志,(我的日志在/var/log/redis/redis-server.log, 日志位置既redis.conf配置里的 logfile配置的位置),发现如下警告:9263:M 21 Nov 20:15:08.943 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect.

警告内容翻译过来就是:警告 重载内存设置为0!在低内存条件下,后台保存可能会失败。要修复这个问题,可以添加'vm '。overcommit_memory = 1'到/etc/sysctl然后重启,或者运行命令 sysctl vm.overcommit_memory=1'

这里Redis已经很明显告诉你解决办法了,继续查看日志,发下如下内容:

9531:M 21 Nov 20:27:36.084 # Can't save in background: fork: Cannot allocate memory

不能后台保存,不能分配内存

具体原因:https://www.linuxidc.com/Linux/2012-07/66079.htm 这位大侠写的很清楚了,解决办法就是修改vm.overcommit_memory = 1,修改方法:

(1)编辑/etc/sysctl.conf ,改vm.overcommit_memory=1,然后sysctl -p 使配置文件生效(需要root权限)

(2)sudo sysctl vm.overcommit_memory=1

vm.overcommit_memory不同值的意义:

0 — 默认设置。表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程,这个设置有时可能会造成系统中的可用内存超载。
1 — 内核执行无内存过量使用处理。表示内核允许分配所有的物理内存,而不管当前的内存状态如何,使用这个设置会增大内存超载的可能性,但也可以增强大量使用内存任务的性能。
2 — 内存拒绝等于或者大于总可用 swap 大小以及 overcommit_ratio 指定的物理 RAM 比例的内存请求。表示内核允许分配超过所有物理内存和交换空间总和的内存,如果您希望减小内存过度使用的风险,这个设置就是最好的

猜你喜欢

转载自blog.csdn.net/Yanci_/article/details/84334102