OOM-killerが時々資源占有者を殺さないのはなぜですか?

OOM-killerが時々資源占有者を殺さないのはなぜですか?

これをシェルに入力すると、メモリが使い果たされるまで永久に書き込もうとしますx=`yes`。カーネルのOOM-killerが割り当てるバイトがなくなり、すぐに終了する必要があることを知らせるので、メッセージを受け取ります。cannot allocate 18446744071562067968 bytes (4295032832 bytes allocated)yesxcannot allocate <memory>xrealloc

ただし、game_engineリソース不足のために存在しないグラフィックメモリをさらに割り当てるように誰かに要求すると、要求されたメモリを割り当てるためにRAMとCPUが使用されます。

カーネルのOOM-killerがgame_engine大容量メモリを割り当てようとする試みをキャプチャできないのはなぜですかx=`yes`

つまり、実行中でgame_engineユーザーがmemory-hog以降に新しいプロセスを作成していない場合、OOM-killerによってシャットダウンされず、私のシステムを応答せずに回復できない状態にすることが常に成功するのgame_engineはなぜですかgame_engine


私はゲームエンジンを例に挙げました。なぜなら、ゲームエンジンは私の貧しい小さな統合カードに多くのメモリを割り当てる傾向があるからです。しかし、これは多くのリソース集約型Xプロセスが発生するようです。

OOM-killerが効果的ではないか、プロセスメモリを無効にできない状況がありますか?

答え1

実際、OOMキラーに対する最善の解決策はそれを持たないことです。過度のメモリを使用しないようにシステムを設定し、それに依存するアプリケーションとライブラリの使用を拒否します。無限ディスク時代に無制限のスワップを提供するのはどうでしょうか?メモリを使わない限りスワップをコミットする必要はないでしょうか?

あなたの質問に対する答えは、OOMキラーがあなたが思うように機能しないということです。 OOMキラーは、経験的な方法を使用して終了するプロセスを選択し、ルールが常に最後の要求者が終了することを意味するわけではありません。参照。OOMキラーを飼いならす。したがって、OOMキラーが「無効」という問題ではなく、そのうちの1つが望むものとは異なる選択をすることが問題です。

関連情報