内容简介:翻译自: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的背景下解释这里发生了什么吗?
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 forovercommit_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)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Go后台对图片base64解码,并保存至文件服务器。
- 保存和恢复模型
- Android 文件保存
- 通过按钮单击保存PhpSpreadSheet
- javascript – Backbone.js – 在上一个保存前保存模型POST(创建)而不是PUT(更新)请求时出现问题
- 使用二进制保存用户状态
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Search User Interfaces
Marti A. Hearst / Cambridge University Press / 2009-9-21 / USD 59.00
搜索引擎的本质是帮助用户更快、更方便、更有效地查找与获取所需信息。在不断改进搜索算法和提升性能(以技术为中心)的同时,关注用户的信息需求、搜寻行为、界面设计与交互模式是以用户为中心的一条并行发展思路。创新的搜索界面及其配套的交互机制对一项搜索服务的成功来说是至关重要的。Marti Hearst教授带来的这本新作《Search User Interfaces》即是后一条思路的研究成果,将信息检索与人......一起来看看 《Search User Interfaces》 这本书的介绍吧!