ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
基本構文
# 末尾 10 行 (デフォルト)
tail /var/log/syslog
# 末尾 100 行
tail -n 100 /var/log/syslog
tail -100 /var/log/syslog # 短縮形
# 先頭から N 行スキップして残り全部
tail -n +1000 /var/log/syslog # 1000 行目以降全部
# 複数ファイル (ファイル名ヘッダ付き)
tail -n 5 *.log
# パイプ経由 (最後の数行だけ)
ps aux | tail -5
主要オプション
| オプション | 意味 |
|---|---|
-n N / -N | 末尾 N 行 |
-n +N | N 行目以降全部 |
-c N | 末尾 N バイト |
-f / --follow | ファイル末尾に追加されたら表示し続ける |
-F | -f --retry 相当 (logrotate でファイル切替されても追随) |
--pid=PID | 指定プロセス終了で追随終了 |
--retry | ファイルが無くても再試行 |
-s N | 追随時のポーリング間隔 (秒) |
-q | 複数ファイル時のヘッダ抑制 |
-v | 必ずヘッダ表示 |
-f vs -F の違い (logrotate 対応)
# -f: ファイルのインデックスノード (inode) を追随
tail -f /var/log/nginx/access.log
# → logrotate で .log → .log.1 にリネームされると追随できなくなる
# → 新しい .log が作られても古い inode を見続ける
# -F: ファイル名を追随 (logrotate 対応)
tail -F /var/log/nginx/access.log
# → リネーム後、新しい access.log が作成されたら自動的にそちらへ切替
# 確実な書き方
tail -F --retry /var/log/nginx/access.log
# → ファイルがまだ無くてもエラーで止まらず待機
ログ監視の実戦パターン
# 1) リアルタイムにエラーだけ抽出
tail -f /var/log/syslog | grep -E "ERROR|FATAL|CRITICAL"
# 2) 複数ログを並行監視 (ファイル名付き)
tail -F /var/log/nginx/access.log /var/log/nginx/error.log
# 3) 色付け (ccze や grc を併用)
tail -f /var/log/auth.log | ccze -A
# 4) アクセスログから 404 を即検知
tail -F /var/log/nginx/access.log | awk '$9 == 404'
# 5) Slack 通知 (重大エラーのみ)
tail -F /var/log/myapp.log | grep --line-buffered "FATAL" | while read line; do
curl -X POST -H 'Content-type: application/json' \
--data "{\"text\":\"FATAL: $line\"}" \
https://hooks.slack.com/services/XXX/YYY/ZZZ
done
# 6) less +F で「追随しつつスクロールも可能」
less +F /var/log/syslog
# → Ctrl+C で追随停止、矢印キーでスクロール、Shift+F で追随再開、q で終了
head との比較
| コマンド | 動作 |
|---|---|
head file | 先頭 10 行 |
head -100 file | 先頭 100 行 |
head -n -10 file | 末尾 10 行を除いた残り全部 |
tail file | 末尾 10 行 |
tail -100 file | 末尾 100 行 |
tail -n +10 file | 10 行目以降全部 |
journalctl との比較 (systemd 環境)
# systemd では多くのログが /var/log/syslog ではなく journald 管理
# → tail でなく journalctl を使う
# tail -f の代わり
journalctl -f
# 特定サービス
journalctl -u nginx -f
journalctl -u myapp.service -f --since "1 hour ago"
# 直近 100 行
journalctl -n 100
# カーネルログ
journalctl -k -f
# 優先度フィルタ
journalctl -p err -f # err 以上
journalctl -p warning..err # 範囲指定
Windows / PowerShell での tail 相当
# 末尾 10 行
Get-Content -Tail 10 C:\logs\app.log
# 末尾 100 行
Get-Content -Tail 100 C:\logs\app.log
# tail -f 相当 (追随)
Get-Content -Tail 10 -Wait C:\logs\app.log
# 別名 (PowerShell 7+ で gc は Get-Content)
gc -Tail 10 -Wait C:\logs\app.log
# grep 相当の絞り込み
Get-Content -Tail 100 -Wait C:\logs\app.log | Select-String "ERROR"
# Linux 風に書きたい場合 (WSL or Git Bash)
wsl tail -f /mnt/c/logs/app.log
リモートサーバの tail
# SSH 経由でリモートのログを追随
ssh user@server "tail -f /var/log/syslog"
# 複数サーバ並行監視 (xpanes / tmux 等)
for h in web1 web2 web3; do
ssh $h "tail -F /var/log/nginx/access.log" &
done
# Ansible で全ホスト末尾取得
ansible all -m shell -a "tail -n 50 /var/log/syslog"
# 巨大ログを転送せずに集計
ssh user@server "tail -100000 /var/log/access.log | awk '{print \$1}' | sort -u | wc -l"
大きなファイルでの注意
tailはファイル末尾から読むのでサイズが大きくても高速 (10GB でも瞬時)- ただし パイプの先で sort や grep -v をすると全データを処理するので遅い
- バイナリファイルを tail すると端末が壊れることがある →
tail file | cat -vで escape - 圧縮ログは
zcat file.gz | tailまたはzless
FAQ
Q: tail -f しているのに新しい行が出ない
A: ファイルが回転 (logrotate) された可能性。-F に変えるか、再起動。アプリ側がバッファリングしていることも (stdbuf -oL で line-buffer 化)。
Q: 末尾 N 行をリアルタイムだけ追いたい (過去は不要)
A: tail -f -n 0 file。-n 0 で過去をスキップ、新規追記分だけ表示。
Q: tail と watch の違いは?
A: tail -f はファイルの追記を追随、watch はコマンドを定期実行 (例: watch -n 1 'df -h')。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページ
子ページはありません
同階層のページ
- ls ファイル/ディレクトリ一覧表示
- sudo ユーザー指定
- cron/crontab ジョブの自動実行と登録方法
- wget http通信によるファイルダウンロード
- rm ファイル/ディレクトリ削除
- pwd カレントディレクトリの表示
- cd ディレクトリの移動
- ./configure
- make
- make install
- unzip ファイルの解凍
- mv ファイル/ディレクトリの移動および名称変更
- mkdir ディレクトリの作成
- touch 空ファイルの新規作成
- vi テキストディタの使用
- find ファイル/ディレクトリ検索
- grep 文字列の検索
- tail ファイルの末尾表示
- curl HTTP通信によるリクエスト
- nslookup ドメインのIP解決
- apt update パッケージリストの情報を更新
- apt upgrade パッケージの更新
- ln リンク/ショートカットの作成と削除
- rsync ファイル/ディレクトリの同期
- ssh リモートとの暗号化通信
- scp sshを利用したファイルのコピー
- unzip zip ファイルを解凍する
- cp ファイル/ディレクトリのコピー
- diffファイルの差分抽出
- fdisk ハードディスクに対する操作
- lsblk デバイスをツリー状で表示する
- kill プロセスを終了させる
- zip ファイルやディレクトリをzip形式に圧縮する
- hostコマンド
- chmod 権限の変更
- ip IPアドレスの確認
- chown コマンド(所有者の変更)
- chgrp ファイル/ディレクトリのグループ情報の変更
- nohupと'&' プログラムのバックグラウンド実行(ssh接続時)
- lsof 開いているポート番号の確認
- tar ファイルの圧縮と解凍
- file ファイルの種類を表示
- cat ファイルの中身を表示
- head ファイルの先頭部分を表示
- wc 行数/単語数/文字数を確認
- shutdown システムのシャットダウンと再起動
- ps プロセスの確認
- which コマンドの絶対パスを調べる
- yum RedHat系ディストリビューションの管理
- mount ファイルシステムのマウント
- 特定フォルダ以下の特定拡張子のファイルを再帰的に削除する方法
- 特定のフォルダとそのサブフォルダ内にある特定のファイル名のファイルを再帰的に削除
- sed テキスト処理用ストリームエディタ
- awk フィールド単位の柔軟なテキスト処理
- sort 行の並び替え
- uniq 重複行の除去・カウント
- cut 行から特定列を切り出し
- tr 文字の置換・削除
- less ページャでファイルを読む
- more 古典ページャ
- xargs 標準入力をコマンド引数に変換
- paste 複数ファイルを列方向に結合
- top プロセスの動的監視
- htop 強化版インタラクティブプロセス監視
- nice プロセスの優先度を指定して起動
- renice 実行中プロセスの優先度を変更
- jobs シェル管理下のジョブ一覧
- bg ジョブをバックグラウンドで実行
- fg バックグラウンドジョブをフォアグラウンドに
- killall プロセス名でまとめて終了
- pgrep プロセス名から PID を検索
- pkill プロセス名でシグナルを送信
- uname システム情報の表示
- uptime システム稼働時間とロードアベレージ
- free メモリ使用状況の表示
- df ディスク使用量 (ファイルシステム単位)
- du ディレクトリ・ファイル単位の使用量
- lscpu CPU 情報の表示
- lsmod 読み込み済みカーネルモジュール一覧
- lspci PCI デバイス一覧
- dmesg カーネルリングバッファの表示
- w ログイン中ユーザーと負荷の表示
- ping ホストへの到達性とラウンドトリップ確認
- traceroute ホストまでの経路を表示
- netstat ネットワーク接続・ルーティング表示 (旧式)
- ss netstat 後継、ソケット統計
- ifconfig ネットワークインターフェース表示・設定 (旧式)
- dig DNS リゾルバ問い合わせの定番
- route ルーティングテーブル表示 (旧式)
- iptables Linux パケットフィルタリング
- telnet TCP 接続診断・古典的リモートログイン
- arp ARP テーブルの表示・編集 (旧式)
- useradd ユーザーアカウントの作成
- usermod 既存ユーザーアカウントの変更
- userdel ユーザーアカウントの削除
- passwd パスワードの変更・管理
- groupadd グループの追加
- id ユーザーとグループの ID・所属を表示
- whoami 現在のユーザー名を表示
- su 別ユーザーに切り替え
- dnf Red Hat 系の次世代パッケージマネージャ (yum 後継)
- pacman Arch Linux のパッケージマネージャ
- echo 文字列・変数の出力
- export 環境変数の設定と継承
- alias コマンドの別名定義
- source / . スクリプトをカレントシェルで実行
- history コマンド履歴の表示・操作
- type コマンドの種別 (組み込み/関数/エイリアス/外部) を表示
- env 環境変数表示と一時設定でコマンド実行
- set シェルオプションと位置パラメータの操作
- unset 変数・関数の削除
- printf C 風書式付き出力
- systemctl systemd ユニットの管理
- service init.d 互換のサービス管理
- journalctl systemd ジャーナルログの参照
- crontab 定期実行ジョブの登録・編集
- at 指定時刻に 1 回だけコマンド実行
- umount ファイルシステムのアンマウント
- reboot システムを再起動
- halt システムを停止
- date 日付・時刻の表示と設定
- hostname ホスト名の表示・設定
- gzip ファイルを Deflate で圧縮
- gunzip gzip 圧縮ファイルの展開
- bzip2 高圧縮率の圧縮コマンド
- xz LZMA2 ベースの高圧縮コマンド
- zstd Facebook 製の高速圧縮コマンド
- dpkg Debian パッケージの低レベル操作
- rpm Red Hat パッケージの低レベル操作
- snap Canonical の sandbox パッケージマネージャ
- apt Debian/Ubuntu の高レベルパッケージマネージャ
- 7z 7-Zip コマンドラインツール
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?