この内容は古いバージョンです。最新バージョンを表示するには、戻るボタンを押してください。
バージョン:7
ページ更新者:atom
更新日時:2026-06-11 07:10:02

タイトル: rm ファイル/ディレクトリ削除
SEOタイトル: Linux rm コマンド完全ガイド (安全な使い方 / -rf の危険性 / 復元手段)

この記事の要点
  • rm ファイル: ファイル削除。rm -r ディレクトリ: ディレクトリ再帰削除
  • -f は確認なし強制、-i は対話確認。-rf は本番で誤爆事故多発
  • ハイフン始まりのファイルは rm -- -file または rm ./-file
  • rm はゴミ箱に入れず即時削除。復元困難 → trash-cli 推奨
  • Windows: del(ファイル)/ rmdir /s /q(ディレクトリ)/ PowerShell Remove-Item -Recurse -Force

rm の基本

rm(remove)はファイル・ディレクトリを即時削除するコマンドです。ゴミ箱には入らず、復元は基本的に不可能。Linux で最も注意すべきコマンドの 1 つです。

# 基本: ファイル 1 つを削除
rm file.txt

# 複数ファイル
rm a.txt b.txt c.txt

# ワイルドカード
rm *.log
rm /tmp/cache_*

# ディレクトリ削除には -r 必須
rm -r mydir

# 強制(確認なし、警告も出さない)
rm -f file.txt
rm -rf mydir/    # ★ 最も危険

# 対話確認
rm -i file.txt
# rm: remove regular file 'file.txt'? y

# 詳細表示
rm -v *.log
# removed 'a.log'
# removed 'b.log'

主要オプション

オプション意味備考
-r / -R / --recursiveディレクトリ再帰削除ディレクトリには必須
-f / --force存在しなくてもエラーにしない、確認しないスクリプト用途
-i毎回確認大事な作業時
-I3 ファイル以上 or 再帰時のみ確認-i よりマシ
-v詳細表示削除確認
-d空ディレクトリのみ削除rmdir と同等
--preserve-root/ 削除を防ぐ(既定)明示的に上書き不可
--no-preserve-root/ 削除を許可絶対使わない
--以降をオプションでなくファイル名として扱うハイフン始まり対応

恐怖の rm -rf /

歴史的に多数の事故が報告される最危険コマンド:

# ❌ システム全消去(GNU coreutils 8.x 以降は既定で拒否)
sudo rm -rf /
# rm: it is dangerous to operate recursively on '/'
# rm: use --no-preserve-root to override this failsafe

# ❌ 同等の事故例
sudo rm -rf /*

# ❌ 環境変数の典型事故
DIR=/foo/bar
rm -rf $DIR/   # ← $DIR が空だと rm -rf / と等価

# ✅ 安全な書き方
DIR=/foo/bar
rm -rf "${DIR:?ERROR: DIR is empty}"/

変数を使うときの安全策

# 1. 必ずダブルクォート
rm -rf "$DIR"

# 2. 空ガード
rm -rf "${DIR:?変数が空}"/

# 3. 削除前の echo で確認
echo rm -rf "$DIR"
# 問題なければ echo を外す

# 4. ls で対象確認
ls -la "$DIR"

# 5. 最終手段: trash-cli で論理削除
trash "$DIR"

ハイフン始まりのファイル

-file.txt のような名前のファイルは、rm がオプションと解釈してしまい削除できません:

# ❌
rm -file.txt
# rm: invalid option -- 'f'

# ✅ 方法1: -- 以降はファイル名
rm -- -file.txt

# ✅ 方法2: ./ プレフィックス
rm ./-file.txt

削除できないファイル

エラー原因対処
Permission denied権限不足sudo rm または chmod
Operation not permitted不変属性(chattr +i)sudo chattr -i で解除
Device or resource busyプロセスがファイル開いているlsof file でプロセス特定 → kill
Directory not empty-r なしでディレクトリ削除rm -r dir
Read-only file systemFS が ro マウントmount -o remount,rw /

削除したファイルの復元

rm はゴミ箱を経由しないため復元は困難ですが、ファイルシステム種別により可能性があります:

FSツール成功率
ext3/4extundelete / ext4magic中(書込前ならあり)
NTFSntfsundelete / TestDisk
FAT32 / exFATphotorec / TestDisk中〜高
Btrfs / ZFSスナップショット有効化済なら高
tmpfs / overlayfs不可

共通の鉄則: 削除に気付いたら即座にそのディスクへの書込を停止(アンマウント or 読取専用化)。書込が起きるほど復元率は下がります。

安全な代替: trash-cli(論理削除)

# インストール
sudo apt install -y trash-cli      # Debian/Ubuntu
sudo dnf install -y trash-cli      # RHEL系
brew install trash-cli             # macOS

# 使い方(rm の代わりに)
trash file.txt                     # ~/.local/share/Trash/files/ へ移動
trash mydir/

# 一覧
trash-list

# 復元
trash-restore

# 空にする
trash-empty

# rm をエイリアスで置換(推奨設定)
alias rm='trash'

定番の安全ガード

# ~/.bashrc に追加
alias rm='rm -i'              # 毎回確認
alias cp='cp -i'
alias mv='mv -i'

# シェルスクリプト内では set -u で未定義変数エラー
set -u
set -e
rm -rf "$undefined_var"/      # → エラーで止まる

# Bash 5+ なら nameref で配列安全
declare -a TARGETS=("/tmp/foo" "/tmp/bar")
for t in "${TARGETS[@]}"; do
    [[ -d "$t" ]] && rm -rf "$t"
done

find と組み合わせた一括削除

# 30 日以上前の .log を削除
find /var/log -name "*.log" -mtime +30 -delete

# 同じく rm 経由(より柔軟)
find /var/log -name "*.log" -mtime +30 -exec rm -f {} \;

# 確認してから削除(推奨)
find /var/log -name "*.log" -mtime +30 -print     # まず確認
find /var/log -name "*.log" -mtime +30 -delete    # 問題なければ実行

# 空ディレクトリだけ削除
find /tmp -type d -empty -delete

# xargs で高速化
find . -name "*.bak" -print0 | xargs -0 rm -f

Windows の同等コマンド

シェルファイル削除ディレクトリ削除
cmd.exedel file.txtrmdir /s /q dir
PowerShellRemove-Item file.txtRemove-Item dir -Recurse -Force
WSL / Git Bashrm file.txtrm -r dir

FAQ

Q: rm * .log と書いてしまった(スペース挟んだ)
A: 全ファイル + .log 削除になります。復元は extundelete に賭けるしかありません。本番では必ず echo rm * で確認。

Q: rm -rf .* も危険?
A: 一部の ... も含まれる場合があり、危険です。Bash 5+ は除外しますが、シェル依存なので使わないでください。

Q: rm が遅い
A: 数百万ファイル削除は find ... -deletersync --delete の方が速い。rm -rf bigdir はメモリ大量消費。

Q: ファイル数が多すぎて Argument list too long
A: find . -name "*.tmp" -deletexargs を使う。ワイルドカード展開はカーネル ARG_MAX 制限あり。