Rainbow Engine

IT技術を分かりやすく簡潔にまとめることによる学習の効率化、また日常の気付きを記録に残すことを目指します。

Linux

Linuxでinodeが枯渇した時の対処方法について

投稿日:2021年12月28日 更新日:

 

<目次>

(1) Linuxでinodeが枯渇した時の対処方法について
 (1-1) エラーメッセージ
 (1-2) 原因
 (1-3) 対策

(1) Linuxでinodeが枯渇した時の対処方法について

(1-1) エラーメッセージ

「df -i」コマンドの出力結果で「IUse」の値が100%になっており、Oracle DBでSQL*Plusにログイン出来ない状況。
 
(図111)
 
(例)
[oracle@tk2-216-17994 bin]$ df -i
Filesystem      Inodes   IUsed  IFree IUse% Mounted on
/dev/vda3      6414336 6414336      0  100% /
tmpfs           240224       3 240221    1% /dev/shm
/dev/vda1        64000      50  63950    1% /boot
 

(1-2) 原因

ディスク自体に空きはあるものの、ファイル数が膨大な事が原因で「inode」が逼迫し、上限値に抵触したのが原因と推定されます。
 
「inode」はファイル単位で付与されるため、微小な(例:1バイト)のファイルが大量にあった場合、ディスク容量が枯渇するよりも先に「inode」の使用量が上限に達する可能性があります。
 
「inode」の概念や上限値の決定方法について知りたい方は下記も併せてご確認頂けたらと思います。
 

(1-3) 対策

●①原因フォルダの段階的な特定

次は「inode」枯渇の原因となるファイル(があるディレクトリ)を特定します。特定には以下のコマンドを使います(root権限で実行)。
 
(構文)指定ディレクトリ配下の各フォルダのファイル数をチェック
# for i in [対象ディレクトリ]/*; do echo $i; find $i |wc -l; done
 
(例)root直下の各フォルダのファイル数をチェック
# for i in /*; do echo $i; find $i |wc -l; done
 
 
(コマンドの補足説明)=========================
・前半部分で、ルート(/)配下のフォルダを順番にループしています。
for i in /*; do echo $i; done
 
(図121)

・後半部分で、ルート(/)配下の各フォルダについて、「find」でフォルダ内の一覧を出力し、「wc」でその数(行数)を数えています。これが結果として、配下のファイルの数になります。

find $i |wc -l
(図122)
 
=======================================
 
まずはこのチェックをroot直下(/*)から始めて、徐々に範囲を絞っていきます。つまり、実行結果でファイル数が多かった箇所を、次のコマンド実行の[対象ディレクトリ]に指定して、どんどんアタリを付けていきます。
 
以下の例は、まず「/*」→「/tmp/*」と範囲を絞っていき、「/tmp/orbit-oracle」配下が原因と特定した例です。
 
(例)1回目は「/*」に対して実行
[root@tk2-216-17994 admin]# for i in /*; do echo $i; find $i |wc -l; done
/bin
113
~~~~中略~~~~
/tmp
6254315
~~~~中略~~~~
↓
(例)2回目は「/tmp/*」に対して実行
[root@tk2-216-17994 tmp]# for i in /tmp/*; do echo $i; find $i |wc -l; done
/tmp/gconfd-oracle
1
~~~~中略~~~~
/tmp/orbit-oracle
6254226
~~~~中略~~~~
(図123)

●②原因ファイルの削除

今回の例では「/tmp/orbit-oracle」配下に600万以上の不要な微小ファイルが生成されていたため、そちらを全て削除した結果、inodeの使用率が3%程度まで減少しました。
 
(図124)

(例)
# オーソドックスな削除(「/tmp/orbit-oracle」配下)
$ rm -rf /tmp/orbit-oracle/*
# 削除対象が膨大で削除できない場合
$ echo /tmp/orbit-oracle/* | xargs rm -f

(例)実行すると、inodeの使用率が徐々に減っていく
[admin@tk2-216-17994 ~]$ df -i
Filesystem      Inodes   IUsed  IFree IUse% Mounted on
/dev/vda3      6414336 6162282 252054   97% /
tmpfs           240224       1 240223    1% /dev/shm
/dev/vda1        64000      50  63950    1% /boot
~~~~中略~~~~
[oracle@tk2-216-17994 admin]$ df -i
Filesystem      Inodes  IUsed   IFree IUse% Mounted on
/dev/vda3      6414336 159875 6254461    3% /
tmpfs           240224      1  240223    1% /dev/shm
/dev/vda1        64000     50   63950    1% /boot
(図125)

Adsense審査用広告コード


Adsense審査用広告コード


-Linux

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

CentOS7でfirewalldを用いてポートの開放を行う方法について

(0)目次&概説 (1) パケットフィルタリングの概要  (1-1) CentOS7のパケットフィルタリング概要  (1-2) CentOS6(iptables)との主な違い  (1-3) 「ゾーン」 …

CentOS6の日本語入力の設定中に起きた「Unable to keep Input Method running」エラーや文字化けの対処方法について

(0)目次&概説 (1) 記事の目的 (2) 日本語化の対応手順 (3) 各パッケージの補足説明 (4) エラー対処:IBusの”Unable to keep Input Method R …

Linux系OSのパッケージ管理システム(rpmやyum)及びリポジトリ(epel)について

(0)目次&概説 (1) 記事の目的  (1-1) 目的  (1-2) 前提条件 (2) rpm(パッケージ管理システム)  (2-1) rpmとは?  (2-2) rpmコマンド(追加・更新・削除) …

Linuxで環境変数を永続化させる方法と手順について

<目次> (1) Linuxで環境変数を永続化させる方法と手順について  (1-1) 実現方法  (1-2) 設定手順 (1) Linuxで環境変数を永続化させる方法と手順について Linuxにおいて …

パイプ通信とは?概要やサンプルプログラムをご紹介

  <目次> (1) パイプ通信とは?概要やサンプルプログラムをご紹介  (1-1) パイプ通信の概要  (1-2) パイプ通信の構文  (1-3) パイプ通信のサンプルプログラム①(単一プ …

  • English (United States)
  • 日本語
Top