Contents
wp-config.phpの設定
WordPressのデバッグ機能を有効にするために、wp-config.php
に以下の設定を追加します:
デバッグモードを有効化
define('WP_DEBUG', true);
define('WP_DEBUG_LOG', true);
define('WP_DEBUG_DISPLAY', false);
エラーの種類
1)自動的に出力されるログ
- データベース接続エラー
- PHP自体のエラー(Fatal Error, Warning, Notice)
- WordPressコア、テーマ、プラグインからのエラー
- データベースクエリエラー
2)error_log()による明示的なログ
error_log('カスタムメッセージ: ' . $変数);
- 開発者が意図的に出力する情報
- デバッグ目的のカスタムメッセージ
- 特定の処理の実行確認
debug.logの権限確認と設定
SSHでサーバーに接続
WordPressのwp-content/フォルダで権限確認
# 現在の位置を確認し、wp-contentディレクトリに移動します
cd public_html/wp-content/
# wp-contentディレクトリ内のファイル一覧と権限を確認
ls -la wp-content
# 下記の出力
[xx@svxxx public_html]$ cd wp-content/
[xx@svxxx wp-content]$ ls -la
合計 244
drwxr-xr-x 8 [所有者] members 179 1月 5 20:55 .
drwx--x--x 18 [所有者] members 4096 1月 5 18:24 ..
-rw-r--r-- 1 [所有者] members 226399 1月 5 21:15 debug.log
-rw-r--r-- 1 [所有者] members 28 1月 26 2022 index.php
drwxr-xr-x 4 [所有者] members 4096 1月 5 17:42 languages
drwxr-xr-x 14 [所有者] members 4096 1月 5 20:48 plugins
drwxr-xr-x 5 [所有者] members 110 1月 5 20:55 themes
....
-rw-r--r--
→ 644(読み取り専用)
この管理者権限の設定で
- 所有者(6): WordPress(PHP)が書き込み可能
- 閲覧者(4): 管理者やツールが読み取り可能
もし権限がちがっていたら変更
# debug.logファイルの権限を変更(書き込み可能に)
chmod 666 wp-content/debug.log
ログの確認
tail -f debug.log # リアルタイムで監視
# または
tail -n 50 debug.log # 最後の50行を表示
権限の見方:
4. ログファイルの確認方法
# ログファイルの内容を表示
cat wp-content/debug.log
# ログをリアルタイムで監視
tail -f wp-content/debug.log
debug.logを削除し管理
debug.logを削除しても、次にデバッグログを出力する必要が生じた時点で、WordPressは自動的に新しいdebug.logファイルを作成します。
いくつかのおすすめの管理方法をご紹介します:
- 定期的なクリーンアップ
- サイトの状況に応じて、月1回や四半期に1回など、定期的なタイミングで削除
- 特に問題調査後は、不要なログが残り続けることを防ぐため削除を検討
- サイズベースの管理
- ファイルサイズが一定量(例:10MBなど)を超えたら削除
- サーバー容量の節約にもなります
- ログローテーション より高度な方法として、ログローテーションの仕組みを導入することもできます。これにより:
- 古いログを自動的にアーカイブ
- 一定期間経過したログを自動削除
- ファイルサイズの制限
デバッグ情報の出力方法
PHPファイルでログを出力する例:
// 基本的なログ出力
error_log('Debug message here');
// 配列やオブジェクトの内容を出力
error_log(print_r($variable, true));