グラフィックスのグラファイトサポートとインターフェイスとしてのicingaweb2を使用して、他の5台を監視するために仮想マシンにicinga2をインストールしました。最近、私のWebインターフェイスで次のようになりました。
Fatal error: Uncaught exception 'ErrorException' with message 'session_start(): open(/var/lib/php5/sess_3aabfsu76vcdj2hd2u3teofta5dvanpn, O_RDWR) failed: No space left on device (28)' in /usr/share/php/Icinga/Web/Session/PhpSession.php:105 Stack trace: #0 [internal function]: Icinga\Application\ApplicationBootstrap->Icinga\Application\{closure}(2, 'session_start()...', '/usr/share/php/...', 105, Array) #1 /usr/share/php/Icinga/Web/Session/PhpSession.php(105): session_start() #2 /usr/share/php/Icinga/Web/Session/PhpSession.php(215): Icinga\Web\Session\PhpSession->open() #3 /usr/share/php/Icinga/Authentication/Auth.php(344): Icinga\Web\Session\PhpSession->refreshId() #4 /usr/share/php/Icinga/Authentication/Auth.php(166): Icinga\Authentication\Auth->persistCurrentUser() #5 /usr/share/php/Icinga/Authentication/Auth.php(262): Icinga\Authentication\Auth->setAuthenticated(Object(Icinga\User)) #6 /usr/share/php/Icinga/Authentication/Auth.php(93): Icinga\Authentication\Auth->authExternal() #7 /usr/share/php/Icinga/Application/Web. in /usr/share/php/Icinga/Web/Session/PhpSession.php on line 105
Fatal error: Uncaught exception 'ErrorException' with message 'Unknown: open(/var/lib/php5/sess_3aabfsu76vcdj2hd2u3teofta5dvanpn, O_RDWR) failed: No space left on device (28)' in Unknown:0 Stack trace: #0 [internal function]: Icinga\Application\ApplicationBootstrap->Icinga\Application\{closure}(2, 'Unknown: open(/...', 'Unknown', 0, Array) #1 {main} thrown in Unknown on line 0
何が起こっているのかを確認するために、ディスクの空き領域に問題があることを見つけようとしました。
# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/hostname--vg-root 6.5G 4.8G 1.4G 78% /
tmpfs 201M 412K 200M 1% /run
...
...
/dev/sda1 236M 154M 70M 69% /boot
問題は、実行されたiノードで発生しました。
#df -i
Filesystem Inodes IUsed IFree IUse% Mounted on
/dev/mapper/hostname--vg-root 441504 441504 0 100% /
...
...
/dev/sda1 62248 318 61930 1% /boot
私が行った小さなファイルの最大の部分がどこにあるかを確認するには:
#for i in /*; do echo $i; find $i |wc -l; done
そして、ポイントがにあることがわかりました / usr そして / var/pool/icinga2/perfdata / ディレクトリ
/usr
177882
/var/spool/icinga2/perfdata
229326
問題は、icinga2がパフォーマンスデータをクリーンアップしない理由と、損傷を与えることなく手動でクリーンアップする方法にあります。ありがとう。
Icinga 2は、ローテーションされたパフォーマンスデータファイルをクリーンアップしません。外部デーモン/アプリケーションが処理後にこれらのファイルを削除することを期待しています。たとえば、PNPを使用している場合、NPCDデーモンはローテーションされたファイルを収集し、それらを処理して、後で削除します。
また、このような問題を事前に確認するために、iノードしきい値を使用した「ディスク」チェックを監視に追加することもできます。