gpt4 book ai didi

memory - 选择 redis maxmemory 大小和 BGSAVE 内存使用量

转载 作者:IT王子 更新时间:2023-10-28 23:34:47 24 4
gpt4 key购买 nike

我正在尝试找出在以下情况下“maxmemory”的安全设置是什么:

  • 编写繁重的应用程序
  • 8GB 内存
  • 假设其他进程占用大约 1GB
  • 这意味着redis进程的内存使用量永远不会超过7GB
  • 每个 BGSAVE 事件的内存使用量都会翻倍,因为:

在redis中docs以下是关于 BGSAVE 事件中内存使用量增加的说法:

If you are using Redis in a very write-heavy application, while saving an RDB file on disk or rewriting the AOF log Redis may use up to 2 times the memory normally used.

  • maxmemory 限制大致与 redis-cli INFO 中的“used_memory”进行比较(如 here 所述),并且不考虑 redis 使用的其他内存

我是否正确,这意味着在这种情况下,maxmemory 设置应设置为不高于 (8GB - 1GB)/2 = 3.5GB?

如果是这样,我将为 redis 文档创建一个拉取请求以更清楚地反射(reflect)这一点。

最佳答案

在这种情况下,我建议限制为 3GB。是的,文档非常正确,运行 bgsave 将在短期内使内存需求翻倍。不过,我更愿意为系统保留 2GB 内存,或者最多为持久主控保留 40% 的最大内存。

您表示您的应用程序编写量很大。在这种情况下,我强烈建议第二台服务器执行保存操作。我发现在高写入和 bgsave 对客户端的响应时间可能会变高。它不是 Redis 本身造成的,而是服务器本身的响应。对于虚拟机尤其如此。在此设置下,您将使用第二个服务器从主服务器从属服务器并保存到磁盘,而第一个服务器保持响应。

关于memory - 选择 redis maxmemory 大小和 BGSAVE 内存使用量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14958799/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com