2.

Linux sudo コマンド完全ガイド (-u / -i / sudoers / NOPASSWD)

編集
この記事の要点
  • sudo command: 一時的に root 権限で実行
  • sudo -u username command: 別ユーザー(root 以外)として実行
  • sudo -i / sudo su -: ログインシェルで root に
  • visudo/etc/sudoers を構文チェック付き編集。直編集は破滅的事故の元
  • NOPASSWD: パスワード省略可。CI / Ansible 自動化で活躍

sudo の基本

sudo(superuser do)は、許可されたユーザーが一時的に別ユーザー権限でコマンドを実行するためのツールです。root への直接ログインを避け、操作ログを /var/log/auth.log に残せるため、セキュリティ的に必須の仕組み。

# 基本: root としてコマンド実行
sudo apt update

# 別ユーザーとして実行(root 以外)
sudo -u www-data php artisan migrate
sudo -u postgres psql

# シェルを root で開く(ログインシェル)
sudo -i
# または
sudo su -

# 非ログインシェル
sudo -s

# 環境変数を保持
sudo -E env | grep PATH

主要オプション

オプション意味
-u user指定ユーザーとして実行(既定 root)
-g group指定グループで実行
-iログインシェル起動(.bash_profile 読込)
-sシェル起動(環境保持)
-E環境変数を保持
-HHOME を対象ユーザーのものに
-kキャッシュされたパスワード破棄
-Kキャッシュを完全消去
-vパスワード入力なしで認証期限を延長
-l自分が実行できる sudo を一覧
-bバックグラウンド実行

別ユーザーで実行(-u)

# Web サーバユーザーで Laravel コマンド
sudo -u www-data php artisan migrate
sudo -u www-data php artisan cache:clear

# PostgreSQL の管理ユーザーで psql
sudo -u postgres psql
sudo -u postgres createuser myapp

# 他人のアカウントでテスト(要 sudoers 許可)
sudo -u taro -i

# UID で指定も可
sudo -u '#1001' command

ログインシェルで root に

# sudo -i : root のログインシェル
sudo -i
# → /root に cd、root の .bash_profile 読み込み

# sudo su -
sudo su -
# → 同上

# sudo -s : 自分のシェルを root 化
sudo -s
# → 現在ディレクトリのまま、自分の .bashrc

# 違いまとめ
# sudo -i  : HOME=/root, 環境クリーン  ← 推奨
# sudo -s  : HOME=自分, 環境継承
# sudo su  : HOME=自分, 環境継承(古い)
# sudo su -: HOME=/root, 環境クリーン

sudoers ファイルの編集(visudo)

/etc/sudoers直接 vi で編集してはいけません。構文エラーがあると sudo が機能しなくなり、root にログインできなくなる事故が起きます:

# 必ず visudo を使う(構文チェック付き)
sudo visudo

# 別ファイル(推奨)
sudo visudo -f /etc/sudoers.d/myrule

# 構文だけチェック
sudo visudo -c

sudoers の書式

# /etc/sudoers の文法
# ユーザー  ホスト=(実行ユーザー:グループ) [タグ:]コマンド

# root はどこでも全コマンド OK
root        ALL=(ALL:ALL) ALL

# sudo グループ全員、全コマンド許可
%sudo       ALL=(ALL:ALL) ALL

# wheel グループ(RHEL 系)
%wheel      ALL=(ALL) ALL

# 特定ユーザーに特定コマンドだけ許可
deploy      ALL=(www-data) NOPASSWD: /usr/bin/php /var/www/artisan *

# 複数コマンドを許可
backup      ALL=(root) NOPASSWD: /usr/bin/rsync, /bin/tar

# 特定ホストのみ
admin       webserver=(ALL) ALL
admin       dbserver=(ALL) ALL

# パスワードなし
deploy      ALL=(ALL) NOPASSWD: ALL    # ← セキュリティ要注意

# パスワード必須に逆指定
deploy      ALL=(ALL) PASSWD: /bin/rm

NOPASSWD(パスワード省略)

# /etc/sudoers.d/deploy
deploy ALL=(ALL) NOPASSWD: ALL

# 限定的な NOPASSWD(推奨)
deploy ALL=(www-data) NOPASSWD: \
    /usr/bin/systemctl restart nginx, \
    /usr/bin/systemctl reload nginx, \
    /usr/bin/php /var/www/artisan *

# 確認: 自分が NOPASSWD で実行できるコマンド
sudo -l
# (root) NOPASSWD: /usr/bin/systemctl restart nginx

Defaults 設定

# /etc/sudoers 内の Defaults

# パスワードキャッシュ時間(分)
Defaults timestamp_timeout=15        # 既定 15 分
Defaults timestamp_timeout=0         # 毎回確認
Defaults timestamp_timeout=-1        # キャッシュ無効化

# 環境変数の引継ぎ
Defaults env_keep += "PATH HOME LANG"

# secure_path(sudo 実行時の PATH)
Defaults secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"

# ログ出力先
Defaults logfile=/var/log/sudo.log

# tty が必要(リモートツール許容のため無効化したい場合)
# Defaults requiretty                # 既定無効
Defaults !requiretty                 # 明示無効

# !authenticate(特定ルールでパスワード要求しない)
deploy ALL=(ALL) NOPASSWD: ALL
# または
deploy ALL=(ALL) !authenticate: ALL

ユーザーを sudo グループに追加

# Ubuntu / Debian
sudo usermod -aG sudo username

# RHEL / CentOS / Rocky
sudo usermod -aG wheel username

# 確認
groups username
id username

# 反映には再ログイン必要
# またはセッション内で
newgrp sudo

ログ確認

# Ubuntu / Debian
sudo tail -f /var/log/auth.log | grep sudo

# RHEL 系
sudo tail -f /var/log/secure | grep sudo

# journalctl 経由(systemd)
sudo journalctl -u sudo --since today
sudo journalctl | grep COMMAND

# 典型ログ
# Mar 15 10:23:45 host sudo:    user : TTY=pts/0 ; PWD=/home/user ;
#   USER=root ; COMMAND=/usr/bin/apt update

便利テクニック

# 1. 直前のコマンドに sudo を付け足し
mkdir /etc/myconfig
# Permission denied
sudo !!
# → sudo mkdir /etc/myconfig

# 2. パイプの先に sudo
ls | sudo tee /etc/log.txt              # 書込側に sudo
echo "127.0.0.1 host" | sudo tee -a /etc/hosts

# 3. sudo で複数コマンド
sudo bash -c 'cd /var/log && rm *.log && systemctl restart nginx'

# 4. ヒアドキュメント
sudo tee /etc/myconfig.conf > /dev/null <<EOF
key1=value1
key2=value2
EOF

# 5. パスワードプロンプトをカスタム
Defaults passprompt="[%u] パスワード: "

セキュリティのベストプラクティス

  • root SSH ログインを無効化: /etc/ssh/sshd_configPermitRootLogin no
  • NOPASSWD は最小コマンドだけに限定NOPASSWD: ALL は実質 root 鍵渡し
  • sudo グループ参加者を定期監査: getent group sudo
  • sudoers.d/ にファイル分割。デプロイ・運用・CI で別ファイル
  • visudo 必須visudo -c で本番反映前に構文確認
  • auth.log を集中ログ管理(rsyslog / Fluentd / CloudWatch Logs)へ転送

FAQ

Q: sudo がパスワードを毎回聞く
A: timestamp_timeout=0 設定の可能性。または異なるターミナルごとに別キャッシュ。Defaults !tty_tickets で全 TTY 共有可能。

Q: sudoers を壊して sudo が使えない
A: シングルユーザーモード(grub で init=/bin/bash)かレスキューモードで起動 → mount -o rw,remount /visudo -c で修正。

Q: sudo su -sudo -i、どちらを使う?
A: sudo -i 推奨。su は古く、PAM 設定差で挙動が違うことがあります。

Q: doas は使うべき?
A: OpenBSD 発祥の軽量 sudo 代替。シンプルで監査しやすい一方、機能は限定的。Linux でも使えるが、エコシステム的には sudo がデファクト。

編集
Post Share
子ページ

子ページはありません

同階層のページ
  1. ls ファイル/ディレクトリ一覧表示
  2. sudo ユーザー指定
  3. cron/crontab ジョブの自動実行と登録方法
  4. wget http通信によるファイルダウンロード
  5. rm ファイル/ディレクトリ削除
  6. pwd カレントディレクトリの表示
  7. cd ディレクトリの移動
  8. ./configure
  9. make
  10. make install
  11. unzip ファイルの解凍
  12. mv ファイル/ディレクトリの移動および名称変更
  13. mkdir ディレクトリの作成
  14. touch 空ファイルの新規作成
  15. vi テキストディタの使用
  16. find ファイル/ディレクトリ検索
  17. grep 文字列の検索
  18. tail ファイルの末尾表示
  19. curl HTTP通信によるリクエスト
  20. nslookup ドメインのIP解決
  21. apt update パッケージリストの情報を更新
  22. apt upgrade パッケージの更新
  23. ln リンク/ショートカットの作成と削除
  24. rsync ファイル/ディレクトリの同期
  25. ssh リモートとの暗号化通信
  26. scp sshを利用したファイルのコピー
  27. unzip zip ファイルを解凍する
  28. cp ファイル/ディレクトリのコピー
  29. diffファイルの差分抽出
  30. fdisk ハードディスクに対する操作
  31. lsblk デバイスをツリー状で表示する
  32. kill プロセスを終了させる
  33. zip ファイルやディレクトリをzip形式に圧縮する
  34. hostコマンド
  35. chmod 権限の変更
  36. ip IPアドレスの確認
  37. chown コマンド(所有者の変更)
  38. chgrp ファイル/ディレクトリのグループ情報の変更
  39. nohupと'&' プログラムのバックグラウンド実行(ssh接続時)
  40. lsof 開いているポート番号の確認
  41. tar ファイルの圧縮と解凍
  42. file ファイルの種類を表示
  43. cat ファイルの中身を表示
  44. head ファイルの先頭部分を表示
  45. wc 行数/単語数/文字数を確認
  46. shutdown システムのシャットダウンと再起動
  47. ps プロセスの確認
  48. which コマンドの絶対パスを調べる
  49. yum RedHat系ディストリビューションの管理
  50. mount ファイルシステムのマウント
  51. 特定フォルダ以下の特定拡張子のファイルを再帰的に削除する方法
  52. 特定のフォルダとそのサブフォルダ内にある特定のファイル名のファイルを再帰的に削除
  53. sed テキスト処理用ストリームエディタ
  54. awk フィールド単位の柔軟なテキスト処理
  55. sort 行の並び替え
  56. uniq 重複行の除去・カウント
  57. cut 行から特定列を切り出し
  58. tr 文字の置換・削除
  59. less ページャでファイルを読む
  60. more 古典ページャ
  61. xargs 標準入力をコマンド引数に変換
  62. paste 複数ファイルを列方向に結合
  63. top プロセスの動的監視
  64. htop 強化版インタラクティブプロセス監視
  65. nice プロセスの優先度を指定して起動
  66. renice 実行中プロセスの優先度を変更
  67. jobs シェル管理下のジョブ一覧
  68. bg ジョブをバックグラウンドで実行
  69. fg バックグラウンドジョブをフォアグラウンドに
  70. killall プロセス名でまとめて終了
  71. pgrep プロセス名から PID を検索
  72. pkill プロセス名でシグナルを送信
  73. uname システム情報の表示
  74. uptime システム稼働時間とロードアベレージ
  75. free メモリ使用状況の表示
  76. df ディスク使用量 (ファイルシステム単位)
  77. du ディレクトリ・ファイル単位の使用量
  78. lscpu CPU 情報の表示
  79. lsmod 読み込み済みカーネルモジュール一覧
  80. lspci PCI デバイス一覧
  81. dmesg カーネルリングバッファの表示
  82. w ログイン中ユーザーと負荷の表示
  83. ping ホストへの到達性とラウンドトリップ確認
  84. traceroute ホストまでの経路を表示
  85. netstat ネットワーク接続・ルーティング表示 (旧式)
  86. ss netstat 後継、ソケット統計
  87. ifconfig ネットワークインターフェース表示・設定 (旧式)
  88. dig DNS リゾルバ問い合わせの定番
  89. route ルーティングテーブル表示 (旧式)
  90. iptables Linux パケットフィルタリング
  91. telnet TCP 接続診断・古典的リモートログイン
  92. arp ARP テーブルの表示・編集 (旧式)
  93. useradd ユーザーアカウントの作成
  94. usermod 既存ユーザーアカウントの変更
  95. userdel ユーザーアカウントの削除
  96. passwd パスワードの変更・管理
  97. groupadd グループの追加
  98. id ユーザーとグループの ID・所属を表示
  99. whoami 現在のユーザー名を表示
  100. su 別ユーザーに切り替え
  101. dnf Red Hat 系の次世代パッケージマネージャ (yum 後継)
  102. pacman Arch Linux のパッケージマネージャ
  103. echo 文字列・変数の出力
  104. export 環境変数の設定と継承
  105. alias コマンドの別名定義
  106. source / . スクリプトをカレントシェルで実行
  107. history コマンド履歴の表示・操作
  108. type コマンドの種別 (組み込み/関数/エイリアス/外部) を表示
  109. env 環境変数表示と一時設定でコマンド実行
  110. set シェルオプションと位置パラメータの操作
  111. unset 変数・関数の削除
  112. printf C 風書式付き出力
  113. systemctl systemd ユニットの管理
  114. service init.d 互換のサービス管理
  115. journalctl systemd ジャーナルログの参照
  116. crontab 定期実行ジョブの登録・編集
  117. at 指定時刻に 1 回だけコマンド実行
  118. umount ファイルシステムのアンマウント
  119. reboot システムを再起動
  120. halt システムを停止
  121. date 日付・時刻の表示と設定
  122. hostname ホスト名の表示・設定
  123. gzip ファイルを Deflate で圧縮
  124. gunzip gzip 圧縮ファイルの展開
  125. bzip2 高圧縮率の圧縮コマンド
  126. xz LZMA2 ベースの高圧縮コマンド
  127. zstd Facebook 製の高速圧縮コマンド
  128. dpkg Debian パッケージの低レベル操作
  129. rpm Red Hat パッケージの低レベル操作
  130. snap Canonical の sandbox パッケージマネージャ
  131. apt Debian/Ubuntu の高レベルパッケージマネージャ
  132. 7z 7-Zip コマンドラインツール

最近更新/作成されたページ