Setzen Sie / proc / sys / vm / drop_caches, um den Cache zu löschen

79

Im Rahmen einiger Cold-Cache-Timings versuche ich, den Betriebssystem-Cache freizugeben. In der Kernel-Dokumentation (abgerufen im Januar 2019) heißt es:

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.

Bei den Details bin ich ein bisschen skizzenhaft. Laufen

echo 3 > /proc/sys/vm/drop_caches

Befreit Pagecache, Dentries und Inodes. Okay.

Muss ich das System zuerst auf 0 zurücksetzen, wenn ich möchte, dass es wieder normal mit dem Cachen beginnt? In meinem System ist der Wert derzeit auf 0 gesetzt, was meiner Meinung nach die Standardeinstellung ist. Oder wird es von alleine zurückgesetzt? Ich sehe hier mindestens zwei Möglichkeiten, und ich bin nicht sicher, welche wahr ist:

  1. echo 3 > /proc/sys/vm/drop_cachesBefreit Pagecache, Dentries und Inodes. Das System beginnt sofort wieder mit dem Caching. Ich bin nicht sicher, was ich von dem Wert erwarten würde /proc/sys/vm/drop_caches, wenn dies der Fall ist. Fast sofort auf 0 zurückkehren?

  2. Wenn /proc/sys/vm/drop_cachesauf 3 gesetzt ist, führt das System keinen Speichercache durch, bis es auf 0 zurückgesetzt wird.

Welcher Fall ist wahr?

Faheem Mitha
quelle
22
Verwendung mit sudo:echo 3 | sudo tee /proc/sys/vm/drop_caches
Volker Siegel
Heiliger Bimbam! @VolkerSiegel Ich habe die Interwebs stundenlang gescrubbt und zufällig Ihren Kommentar gefunden. Versuchte es und es hat perfekt funktioniert! Vielen Dank, dass Sie diesen kleinen Trick hinzugefügt haben. Ich möchte diese Frage nicht missbrauchen, aber wenn sie nicht unangemessen ist, möchte ich Sie um eine Erklärung bitten. Als ich sshpass verwenden mit sudo -i && echo 3 > /proc/sys/vm/drop_caches, erhalte ich eine Fehlermeldung: stdin: is not a tty. Die Verwendung Ihrer "sudo" -Methode funktioniert. Warum?
Harperville
2
@harperville Stellen Sie eine Frage; Dies ist mit ziemlicher Sicherheit ein nicht damit zusammenhängendes Problem.
Faheem Mitha
1
@harperville Ja - das ist eine sehr gute Frage - mit einer interessanten Antwort, bitte separat stellen! Dann lassen Sie es mich hier wissen. Oder möchten Sie, dass ich die Frage selbst stelle und sie dann beantworte?
Volker Siegel

Antworten:

106

Es ist nicht klebrig - Sie schreiben einfach in die Datei, damit sie die Caches löscht, und dann beginnt sie sofort wieder mit dem Cachen.

Grundsätzlich ändern Sie beim Schreiben in diese Datei keine Einstellungen, sondern geben einen Befehl an den Kernel aus. Der Kernel führt diesen Befehl aus (indem er die Caches löscht) und fährt dann wie zuvor fort.

TomH
quelle
2
OK danke. Ändert sich der Wert sofort wieder auf 0?
Faheem Mitha
33
@FaheemMitha Nein, der Wert, den Sie lesen können, ist das, was Sie zuletzt eingegeben haben, aber er wird nirgendwo verwendet, nur die Aktion des Schreibens spielt eine Rolle. Der Quellcode ist in fs/drop_caches.c.
Gilles
Gibt es einen spezifischen Vorteil für die JVM, wenn Sie dies tun?
JE Carter II
3
Es gibt keine Vorteile für Anwendungen, im Gegenteil: Dateien werden langsamer geladen, da keine zwischengespeicherten Inodes vorhanden sind. Auch Sie sind nicht wenig Speicher: Wenn eine App - Speicher braucht es es aus dem OS - Cache statt. Siehe linuxatemyram.com .
dr0i
@TomH, bei "nur die Aktion des Schreibens ist wichtig" ist dies der syncBefehl?
KaizenCoder