キャッシュをクリアするための/ proc / sys / vm / drop_cachesの設定


79

コールドキャッシュタイミングの一部として、OSキャッシュを解放しようとしています。(2019年1月取得した)カーネルのドキュメントは言います:

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

ページキャッシュ、デントリ、およびiノードを解放します。OK。

したがって、システムが再びキャッシュを正常に開始するようにしたい場合、最初に0にリセットする必要がありますか?私のシステムの値は現在0に設定されていますが、これがデフォルトだと思います。または、それ自体でリセットされますか?ここには少なくとも2つの可能性がありますが、どちらが本当かはわかりません:

  1. echo 3 > /proc/sys/vm/drop_cachesページキャッシュ、デントリ、およびiノードを解放します。その後、システムはすぐに再びキャッシュを開始します。/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 14

聖なる牛!@VolkerSiegel Interwebsを数時間スクラブして、ランダムにコメントを見つけました。それを試してみて、それは完全に機能しました!この小さなトリックを追加してくれてありがとう。この質問をハイジャックしたくありませんが、もしそれが不適切でなければ、説明を求めたいです。でsshpassを使用するとsudo -i && echo 3 > /proc/sys/vm/drop_caches、エラーが発生します:stdin: is not a tty。「sudo」メソッドを使用すると動作します。どうして?
ハーパービル

2
@harperville質問する。これはほぼ間違いなく無関係な問題です。
ファヒムミタ

1
@harpervilleはい-それは非常に良い質問です-興味深い答えがあります、別途お尋ねください!次に、ここでお知らせください。または、自分で質問をしてから答えてほしいですか?
フォルカーシーゲル

回答:


106

スティッキーではありません-ファイルに書き込むだけでキャッシュが削除され、すぐにキャッシュが再開されます。

基本的に、そのファイルに書き込むとき、実際に設定を変更するのではなく、カーネルにコマンドを発行しています。カーネルは(キャッシュをドロップすることにより)そのコマンドに基づいて動作し、その後、前と同じように実行します。


2
はい、ありがとう。値はすぐに0に戻りますか?
ファヒムミタ

33
@FaheemMithaいいえ、読み取ることができる値は最後に入力した値です。ただし、どこでも使用されることはなく、書き込みのアクションのみが重要です。ソースコードはですfs/drop_caches.c
ジル

これを行うことにより、JVMに特定の利点はありますか?
JEカーターII

3
逆に、アプリケーションには利点はありません。キャッシュされたiノードがないため、ファイルの読み込みが遅くなります。また、メモリ不足ではありません。アプリがメモリを必要とする場合、OSキャッシュからメモリを取得します。linuxatemyram.comを参照してください。
-dr0i

@TomH、「書くことのアクションだけが問題」で、これはsyncコマンドですか?
kaizenCoder
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.