memory-management rabbitmq内存配置 - 减少RabbitMQ内存使用量




1 Answers

在RabbitMQ中限制内存使用的适当方法是使用vm_memory_high_watermark 。 你说:

我也尝试将vm_memory_high_watermark设置为低于默认值(40%)的几个不同值,甚至低至5%。

应该有效,但可能没有你期望的那样。 在日志中,您将找到一条线,告诉您绝对内存限制是什么,如下所示:

=INFO REPORT==== 29-Oct-2009::15:43:27 ===
Memory limit set to 2048MB.

您需要根据需要调整内存限制 - 如果您在VPS环境中运行,Rabbit可能会将您的系统视为拥有比您认为的更多的RAM。

有时,Rabbit无法分辨您所使用的系统并使用1GB作为基点(因此默认情况下您的限制为410MB)。

此外,请确保您运行的是支持vm_memory_high_watermark设置的RabbitMQ版本 - 理想情况下,您应该使用最新的稳定版本运行。

我试图在一个小型VPS(512mb RAM)上运行RabbitMQ以及Nginx和其他一些程序。 我已经能够毫无困难地调整其他所有内存的使用情况,但我似乎无法让RabbitMQ使用更少的RAM。

我想我需要减少Erlang用于RabbitMQ的线程数,但是我无法让它工作。 我也尝试将vm_memory_high_watermark设置为低于默认值(40%)的几个不同值,甚至低至5%。

部分问题可能是VPS提供程序(MediaTemple)允许我查看我分配的内存,因此当使用free或top时,它显示服务器大约有900mb。

有任何建议可以减少RabbitMQ的内存使用量,或者限制Erlang创建的线程数量吗? 我相信Erlang正在使用30个线程,基于我在进程命令中看到的-A30标志。

理想情况下,我希望RabbitMQ内存使用率低于100mb。

编辑:

vm_memory_high_watermark设置为5%(或配置文件中为0.05),RabbitMQ日志报告RabbitMQ的内存限制设置为51mb。 我不确定51mb来自哪里。 当前VPS分配的内存为924mb,因此其中5%应为46mb左右。

根据启动RabbitMQ之前的htop / free,我坐着大约453mb的二手ram,在启动RabbitMQ之后,我大约650mb。 增加近200mb。 可能是200MB是RabbitMQ运行的下限吗?

编辑2

下面是启动RabbitMQ之前和之后ps aux和free的一些截图 ,以及显示RabbitMQ启动时内存峰值的图表。

编辑3

我也检查没有启用插件,它没有什么区别。 似乎我拥有的插件(管理及其先决条件)仅增加了大约8mb的ram使用量。

编辑4

我不再需要使用此服务器进行测试,但是,有一个conf设置delegate_count设置为默认值16.据我所知,这为rabbitmq产生了16个sup-procs。 在较小的服务器上降低此数字可能有助于减少内存占用。 不知道这是否真的有效,或者它如何影响性能,但这是值得尝试的。




Related