Рейтинг:0

Нужно ли моему серверу подкачки с ~80 ГБ доступной оперативной памяти еще больше?

флаг mx

Я администрирую сервер Debian Linux x86_64 с 125 ГБ ОЗУ, разделом подкачки 10 ГБ и значением подкачки 60.

А бесплатно -gw выходные распечатки:

              общее количество использованных свободных общих буферов доступного кеша
Мем: 125 20 1 25 0 103 78
Обмен: 9 1 7

Каждую ночь запускается задание cron, которое очень интенсивно читает и записывает диск и во время выполнения увеличивает используемую память на 2 ГБ, прежде чем вернуться к ~ 20 ГБ.

В то же время некоторые длительно работающие контейнерные процессы Python (особенно gunicorn) выгружаются.

Со временем эти процессы будут постепенно заполнять своп — через пару недель он будет заполнен на 99%.

Я могу очистить своп, либо перезапустив процессы, либо отключив и снова включив с помощью замена и свопон. Но использование подкачки процессов Python снова будет медленно увеличиваться.

Я предполагаю, что часть объяснения может заключаться в том, что из-за ночной работы cron ядро ​​отдает приоритет кешу файловой системы выше, чем процессам Python. Но я также предполагаю, что в этом может быть виновата какая-то программная ошибка в обработке памяти этими процессами Python.

Друг предложил мне купить еще больше оперативной памяти, чтобы было больше места для кеша файловой системы. Мне это кажется чрезмерным. Хотелось бы точнее диагностировать причину подкачки и найти какое-нибудь программное решение проблемы.

Итак, теперь я передаю вопрос Serverfault — что вы думаете об этом явлении и куда мне двигаться дальше?

Рейтинг:0
флаг jp

Нет, вам не нужно больше оперативной памяти, и вам не нужно делать замена/свопон. Это нормальное поведение, система обнаруживает некоторые редко используемые страницы памяти и перемещает их в раздел подкачки, чтобы использовать оперативную память для чего-то более полезного, например файлового кэша.

eheu avatar
флаг mx
Хорошо, спасибо.Тот факт, что мой раздел подкачки почти заполнен, не кажется ли вам «операционным запахом»? Должен ли я рассмотреть вопрос об увеличении размера моего раздела подкачки? И не заходить слишком далеко на территорию нового вопроса: должен ли вообще быть определенный объем свопа, неиспользованный в случае сценариев убийц OOM - я думаю, я имею в виду эмпирическое правило?
флаг jp
У вас есть 78 ГБ ОЗУ, доступных для выделения и использования до того, как вы начнете получать OOM, поэтому не имеет значения, использует ли система все 10 ГБ подкачки при наличии 78 ГБ ОЗУ. Вы по-прежнему можете добавить немного пространства подкачки, если вы получаете 100% использование подкачки, чтобы система могла подкачивать больше неиспользуемых страниц памяти.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.