Configurando / proc / sys / vm / drop_caches para limpar o cache

80

Como parte de alguns tempos de cache frio, estou tentando liberar o cache do SO. A documentação do kernel (recuperada em janeiro de 2019) diz:

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.

Eu sou um pouco superficial sobre os detalhes. Corrida

echo 3 > /proc/sys/vm/drop_caches

libera pagecache, dentries e inodes. Está bem.

Portanto, se eu quiser que o sistema reinicie o cache normalmente novamente, preciso redefini-lo para 0 primeiro? Meu sistema tem o valor atualmente definido como 0, que eu assumo ser o padrão. Ou será redefinido por conta própria? Vejo pelo menos duas possibilidades aqui e não tenho certeza de qual delas é verdadeira:

  1. echo 3 > /proc/sys/vm/drop_cacheslibera pagecache, dentries e inodes. O sistema inicia imediatamente o cache novamente. Não tenho certeza do que eu esperaria que o valor /proc/sys/vm/drop_cachesfizesse, se esse fosse o caso. Voltar a 0 quase imediatamente?

  2. Se /proc/sys/vm/drop_cachesestiver definido como 3, o sistema não fará cache de memória até que seja redefinido para 0.

Qual caso é verdadeiro?

Faheem Mitha
fonte
22
Para usá-lo com o sudo:echo 3 | sudo tee /proc/sys/vm/drop_caches
Volker Siegel
Vaca sagrada! @VolkerSiegel Estive esfregando as Interwebs por horas e encontrei seu comentário aleatoriamente. Tentei e funcionou perfeitamente! Obrigado por adicionar este pequeno truque. Não quero invadir esta pergunta, mas se não for inadequada, gostaria de pedir uma explicação. Quando eu uso sshpass com sudo -i && echo 3 > /proc/sys/vm/drop_caches, eu recebo um erro: stdin: is not a tty. Usando o seu método "sudo" funciona. Por quê?
harperville
2
@harperville Faça uma pergunta; isso é quase certamente uma questão não relacionada.
Faheem Mitha
1
@harperville Sim - essa é uma pergunta muito boa - com uma resposta interessante, faça separadamente! Então me avise aqui. Ou você quer que eu faça a pergunta pessoalmente e depois responda?
Volker Siegel

Respostas:

107

Não é pegajoso - basta escrever no arquivo para fazer com que ele solte os caches e, em seguida, ele imediatamente começa a fazer o cache novamente.

Basicamente, quando você escreve para esse arquivo, não está realmente alterando uma configuração, está emitindo um comando para o kernel. O kernel age nesse comando (removendo os caches) e continua como antes.

TomH
fonte
2
Ok obrigado. O valor muda imediatamente de volta para 0?
Faheem Mitha
33
@FaheemMitha Não, o valor que você pode ler é o que você coloca por último, mas não é usado em nenhum lugar, apenas a ação de escrever é importante. O código fonte está em fs/drop_caches.c.
Gilles
Existe um benefício específico para a JVM ao fazer isso?
JE Carter II
3
Pelo contrário, não há benefícios para aplicativos: os arquivos serão carregados mais lentamente porque não há inodes em cache. Além disso, você não tem pouca memória: se um aplicativo precisar de memória, ele será retirado do cache do SO. Veja linuxatemyram.com .
dr0i
@ TomH, em "apenas a ação de escrever importa" é este o synccomando?
kaizenCoder 28/08