端くれプログラマの備忘録 CakePHP [CakePHP] ログをファイルに書き出す

[CakePHP] ログをファイルに書き出す

デバッグ用や運用エラーの記録用にログをファイルに書き出したい場合がある。CalePHPには手軽に使えるロギングの仕組みが用意されている。

Logging — CakePHP Cookbook 2.x documentation
http://book.cakephp.org/2.0/en/core-libraries/logging.html

Class CakeLog | CakePHP
http://api.cakephp.org/2.7/class-CakeLog.html

CakePHPのクラスではlog()関数を呼ぶことでログをファイルに書き出すことができる。log()関数は2つの引数を取り、1つ目の引数がログメッセージ、2つ目の引数はログ種別(error, warning, info, debugなど)である。ログ種別がログ出力先のファイル名を決定する。ログ種別を指定しないとLOG_ERRORが使われる。

// Executing this inside a CakePHP class
$this->log("Something didn't work!");

// Results in this being appended to app/tmp/logs/error.log
// 2007-11-02 10:22:02 Error: Something didn't work!

あるいはCakeLog::write()関数を呼ぶことにより、任意のクラスからログを書き出すことができる。write()関数の1つ目の引数にはログ種別、2つ目の引数にはログメッセージを指定する。

// called statically
CakeLog::write('activity', 'A special message for activity logging');

// Results in this being appended to app/tmp/logs/activity.log (rather than error.log)
// 2007-11-02 10:22:02 Activity: A special message for activity logging

config()関数を使ってログの動作オプションを指定することもできる。以下はログファイルのパスを指定した例。注意事項としては、config()関数は必ずapp/Config/bootstrap.phpで呼び出すこと。core.phpで呼び出すと、パスが未設定のために不具合の原因となる。

CakeLog::config('custom_path', array(
    'engine' => 'File',
    'path' => '/path/to/custom/place/'
));

参考サイト

【CakePHP】独自ログ – Qiita
http://qiita.com/kazu56/items/1930bfb8960d52d71a50

CakePHPでログの振り分け(1つのconfigで複数ファイルに) – Qiita
http://qiita.com/HamaTech/items/4c92b36c8c9803c4eec9

CakePHP 2.x – ログローテーション
http://kwski.net/cakephp-2-x/1048/