Установка / proc / sys / vm / drop_caches для очистки кеша


80

В рамках некоторых таймингов холодного кэша я пытаюсь освободить кэш ОС. Документация ядра (полученная в январе 2019 года) гласит:

drop_caches

Writing to this will cause the kernel to drop clean caches, as well as
reclaimable slab objects like dentries and inodes.  Once dropped, their
memory becomes free.

To free pagecache:
    echo 1 > /proc/sys/vm/drop_caches
To free reclaimable slab objects (includes dentries and inodes):
    echo 2 > /proc/sys/vm/drop_caches
To free slab objects and pagecache:
    echo 3 > /proc/sys/vm/drop_caches

This is a non-destructive operation and will not free any dirty objects.
To increase the number of objects freed by this operation, the user may run
`sync' prior to writing to /proc/sys/vm/drop_caches.  This will minimize the
number of dirty objects on the system and create more candidates to be
dropped.

This file is not a means to control the growth of the various kernel caches
(inodes, dentries, pagecache, etc...)  These objects are automatically
reclaimed by the kernel when memory is needed elsewhere on the system.

Use of this file can cause performance problems.  Since it discards cached
objects, it may cost a significant amount of I/O and CPU to recreate the
dropped objects, especially if they were under heavy use.  Because of this,
use outside of a testing or debugging environment is not recommended.

You may see informational messages in your kernel log when this file is
used:

    cat (1234): drop_caches: 3

These are informational only.  They do not mean that anything is wrong
with your system.  To disable them, echo 4 (bit 3) into drop_caches.

Я немного отрывочен в деталях. Бег

echo 3 > /proc/sys/vm/drop_caches

освобождает PageCache, Dentries и Inode. Хорошо.

Итак, если я хочу, чтобы система снова начала нормально кэшировать, нужно ли сначала сбросить его на 0? В моей системе в настоящее время установлено значение 0, которое я предполагаю по умолчанию. Или он сбросится сам по себе? Я вижу по крайней мере две возможности здесь, и я не уверен, какая из них является правдой:

  1. echo 3 > /proc/sys/vm/drop_cachesосвобождает PageCache, Dentries и Inode. Затем система немедленно начинает кэширование снова. Я не уверен, что я ожидал бы получить значение /proc/sys/vm/drop_caches, если это так. Вернуться к 0 почти сразу?

  2. Если /proc/sys/vm/drop_cachesустановлено значение 3, система не выполняет кэширование памяти, пока не будет сброшено до 0.

Какой случай верный?


22
Чтобы использовать его с sudo:echo 3 | sudo tee /proc/sys/vm/drop_caches
Volker Siegel

Святая корова! @VolkerSiegel Я часами чистил интернет и случайно нашел твой комментарий. Попробовал и все заработало отлично! Спасибо за добавление этого маленького трюка. Я не хочу угонять этот вопрос, но если он не является неуместным, я хотел бы попросить объяснений. Когда я использую sshpass с sudo -i && echo 3 > /proc/sys/vm/drop_caches, я получаю сообщение об ошибке: stdin: is not a tty. Использование вашего метода "sudo" работает. Почему?
Harperville

2
@harperville Задайте вопрос; это почти наверняка не связанная проблема.
Фахим Митха

1
@harperville Да - это очень хороший вопрос - с интересным ответом, задавайте его отдельно! Тогда дайте мне знать здесь. Или вы хотите, чтобы я сам задал вопрос, а затем ответил на него?
Фолькер Сигел

Ответы:


107

Он не липкий - вы просто записываете в файл, чтобы он сбрасывал кеш, а затем он немедленно начинает кеширование снова.

По сути, когда вы пишете в этот файл, вы на самом деле не меняете настройки, вы запускаете команду для ядра. Ядро действует по этой команде (удаляя кэши), а затем продолжает работу, как и прежде.


2
Хорошо спасибо. Значение сразу меняется обратно на 0?
Фахим Митха

33
@FaheemMitha Нет, значение, которое вы можете прочитать, это то, что вы ставите последним, но оно нигде не используется, важно только действие письма. Исходный код находится в fs/drop_caches.c.
Жиль

Есть ли конкретная выгода для JVM от этого?
Джей Картер II

3
Для приложений нет никаких преимуществ, наоборот: файлы будут загружаться медленнее, потому что нет кэшированных inode. Кроме того , вы не хватает памяти: если приложение нуждается в памяти он будет принимать его из кэша ОС. Смотрите linuxatemyram.com .
dr0i

@TomH, "только действие письма имеет значение" это syncкоманда?
kaizenCoder
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.