web-dev-qa-db-ja.com

Icinga2perfdataディレクトリがオーバーフローしました

グラフィックスのグラファイトサポートとインターフェイスとしての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がパフォーマンスデータをクリーンアップしない理由と、損傷を与えることなく手動でクリーンアップする方法にあります。ありがとう。

2
Ver

Icinga 2は、ローテーションされたパフォーマンスデータファイルをクリーンアップしません。外部デーモン/アプリケーションが処理後にこれらのファイルを削除することを期待しています。たとえば、PNPを使用している場合、NPCDデーモンはローテーションされたファイルを収集し、それらを処理して、後で削除します。

また、このような問題を事前に確認するために、iノードしきい値を使用した「ディスク」チェックを監視に追加することもできます。

3
dnsmichi