无法在后台保存(redis-server)

栏目: 数据库 · 发布时间: 5年前

内容简介:翻译自:https://stackoverflow.com/questions/42502636/unable-to-save-in-background-redis-server

我有两台 redis 服务器在同一台机器上运行.第二个日志文件有几个实例,其中包含以下通知:

[50818] 19 Feb 06:41:05.007 * 10 changes in 300 seconds. Saving...
[50818] 19 Feb 06:41:05.007 # Can't save in background: fork: Cannot allocate memory

相比之下,第一个日志文件仅包含成功的数据库保存.如果我内存不足,我估计两者都有类似的日志.令我感到困惑的是,只有一个有这个问题,另一个没有.任何线索?

此外,研究让我看到 this blog post ,它认为如果我在命令行上执行sysctl vm.overcommit_memory = 1,问题就可以得到改善.没有解释这有何帮助.有人可以在redis的背景下解释这里发生了什么吗?

按照 Redis FAQs

Background saving is failing with a fork() error under Linux even if I’ve a lot of free RAM!

Short answer: echo 1 > /proc/sys/vm/overcommit_memory

And now the long one:

Redis background saving schema relies on the copy-on-write semantic of

fork in modern operating systems: Redis forks (creates a child

process) that is an exact copy of the parent. The child process dumps

the DB on disk and finally exits. In theory the child should use as

much memory as the parent being a copy, but actually thanks to the

copy-on-write semantic implemented by most modern operating systems

the parent and child process will share the common memory pages. A

page will be duplicated only when it changes in the child or in the

parent. Since in theory all the pages may change while the child

process is saving, Linux can’t tell in advance how much memory the

child will take, so if the overcommit_memory setting is set to zero

fork will fail unless there is as much free RAM as required to really

duplicate all the parent memory pages, with the result that if you

have a Redis dataset of 3 GB and just 2 GB of free memory it will

fail. Setting overcommit_memory to 1 says Linux to relax and perform

the fork in a more optimistic allocation fashion, and this is indeed

what you want for Redis.

A good source to understand how Linux Virtual Memory work and other

alternatives for overcommit_memory and overcommit_ratio is this

classic from Red Hat Magazine, “Understanding Virtual Memory”. Beware,

this article had 1 and 2 configuration values for overcommit_memory

reversed: refer to the 07001 man page for the right meaning of

the available values.

翻译自:https://stackoverflow.com/questions/42502636/unable-to-save-in-background-redis-server


以上所述就是小编给大家介绍的《无法在后台保存(redis-server)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

翻转课堂的可汗学院

翻转课堂的可汗学院

萨尔曼·可汗(Salman Khan) / 刘婧 / 浙江人民出版社 / 2014-4-1 / 49.00元

MIT和哈佛毕业的高材生缘何放弃金融分析师工作投身教育事业?YouTube上的“可汗学院频道”至今共吸引了163.3万订阅者,观看次数超过3.55亿次,它为什么如此大受欢迎?创始人萨尔曼·可汗阐述属于未来的教育理念——让地球上的任何人都能随时随地享受世界一流的免费教育! 现行教育模式已有200余年历史,可汗认为,在互联网蓬勃发展、社交网络盛况空前的时代,免费、灵活、适合个体、全球共享的教育才......一起来看看 《翻转课堂的可汗学院》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试