169 похожих чатов

Кто-Нибудь, случайно, в курсе, как уменьшить аппетиты BEAM по памяти? А

то у меня простое приложение в
:erlang.memory(:total) показывает 54877864,
а VIRT памяти сжирает 4 гига.

21 ответов

67 просмотров

А что не так? Erlang аллоцирует побольше виртуальной памяти сразу, чтобы потом реже к системе обращаться. Приложение, что так, что с ограничениями, реальной памяти потребляет одинаково

Дмитрий-Перцев Автор вопроса
Lama Lover
А что не так? Erlang аллоцирует побольше виртуальн...

Я подозреваю, что если я запихну в контейнер, то он все 4 гига и сожрёт. Завтра проверю. Что-то вот такое: https://elixirforum.com/t/elixir-erlang-docker-containers-ram-usage-on-different-oss-kernels/57251/15

Дмитрий Перцев
Я подозреваю, что если я запихну в контейнер, то о...

Контейнер это же просто процесс в отдельной cgroup. Поэтому виртуальной памяти он может есть сколько хочет, а реальной будет потреблять ровно сколько ему выделит ОС

Дмитрий-Перцев Автор вопроса
Lama Lover
Контейнер это же просто процесс в отдельной cgroup...

Спасибо. Как я понял, если поставить --memory 500m, то OOM killer его грохнет.

Дмитрий-Перцев Автор вопроса
Дмитрий Перцев
screenshot

Это системный OOM-Killer. И там был баг в неправильной конфигурации контейнера. У тебя же процесс потребляет 50мб памяти. Его не убьёт OOM Killer. Виртуальная память это совершенно другая вещь, которая к реальному потреблению слабо относится

Дмитрий-Перцев Автор вопроса

Решение найдено. Если кому интересно: export MALLOC_ARENA_MAX=1 + в vm.args: +Q 1024 +P 1024 +MIscs 128 И потребление падает до 300МБ.

Дмитрий Перцев
Решение найдено. Если кому интересно: export MALLO...

а зачем? это ж виртуальная память, на неё вроде никто в современном мире не смотрит

Дмитрий Перцев
Решение найдено. Если кому интересно: export MALLO...

Зачем ты борешься с виртуальной памятью????

Дмитрий Перцев
У меня её мало.

Ты знаешь что такое "виртуальная память"? Похоже что не совсем

Дмитрий Перцев
У меня её мало.

ты на 32битной машине запускаешься?

Дмитрий Перцев
нет

тогда у тебя не мало virtual memory

Дмитрий Перцев
нет

2^64 байт, если что

Дмитрий Перцев
Решение найдено. Если кому интересно: export MALLO...

Если ты не используешь арены, то у тебя на каждый чих будет дёргаться системный malloc, что зафрагментирует память между процессами и что ещё и просто само по себе будет довольно медленно

Дмитрий-Перцев Автор вопроса
Lama Lover
Если ты не используешь арены, то у тебя на каждый ...

У меня нет даже 5 процессов и не будет на этом кейсе =)

Дмитрий Перцев
Решение найдено. Если кому интересно: export MALLO...

у меня в какой-то момент времени некоторые процессы сошли с ума, в том числе beam. причиной оказалось, что в новой версии ядра (или его конфиге) увеличили ulimit nofile, и каким-то образом это сказалось на потреблении памяти

Дмитрий-Перцев Автор вопроса
Максим Мартынов
у меня в какой-то момент времени некоторые процесс...

Да, было такое. something also changed with systemD) changed from a real limit (1_048_576) to unlimited. With unlimited the mentioned +Q will take it’s maximum allowed value (134_217_727).

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
1
Он в одиночку это дело запилил или была какая-то команда?
Aquinary
12
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Карта сайта