ログローテーション

CakePHP1.3では標準ではログはタイプごとに出力されるだけで、定期的なローテーションを行ってくれません。放っておくとひたすら1つのファイルにアペンドされていきます。app/tmp/logs以下に出力され、Logレベルによってerror.logとdebug.logが出力されます。

// /cake/libs/log/file_log.php [オリジナル]
function write($type, $message) {
    $debugTypes = array('notice', 'info', 'debug');

    if ($type == 'error' || $type == 'warning') {
        $filename = $this->_path    . 'error.log';
    } elseif (in_array($type, $debugTypes)) {
        $filename = $this->_path . 'debug.log';
    } else {
        $filename = $this->_path . $type . '.log';
    }
    $output = date('Y-m-d H:i:s') . ' ' . ucfirst($type) . ': ' . $message."\n";
    $log = new File($filename, true);
    if ($log->writable()) {
        return $log->append($output);
    }
}

ログが日付毎に切り替わるよう変更

$filename = ~ の部分に日付[date('ymd')]を追加しました。
これで、日をまたぐ毎に出力するファイル先が切り替わるようになります。
app/tmp/logs/[yymmdd]_error.log
app/tmp/logs/[yymmdd]_debug.log

// /cake/libs/log/file_log.php [修正後]
function write($type, $message) {
    $debugTypes = array('notice', 'info', 'debug');

    if ($type == 'error' || $type == 'warning') {
        $filename = $this->_path . date('ymd') . '_error.log';
    } elseif (in_array($type, $debugTypes)) {
        $filename = $this->_path . date('ymd') . '_debug.log';
    } else {
        $filename = $this->_path . date('ymd') . '_' . $type . '.log';
    }
    $output = date('Y-m-d H:i:s') . ' ' . ucfirst($type) . ': ' . $message."\n";
    $log = new File($filename, true);
    if ($log->writable()) {
        return $log->append($output);
    }
}

$this->log('ログメッセージ', $levels)でログ出力されます。ちなみにログレベルですが、/cake/libs/cake_log.phpにあります。

LOG_WARNING => 'warning',
LOG_NOTICE => 'notice',
LOG_INFO => 'info',
LOG_DEBUG => 'debug',
LOG_ERR => 'error',
LOG_ERROR => 'error'

[追] もっと簡単な方法がフォーラムに

ログファイル名に日付を付ける
確認したところ、動作してくれました。

// app/config/bootstrap.php
$log_path = LOGS.DS.date('Ymd').'_';
CakeLog::config('default', array('engine' => 'FileLog', 'path' => $log_path));
  • このエントリーをはてなブックマークに追加

関連記事

メール送信(qdmail)

CakePHP(+qdmail)でメール送信する処理を実装しました。 準備 2つのライブラリ(.php)をダウンロードし、以下のように配置して下さい。 app/controllers/compo

no image

Sessionコンポーネント

ソース: /cake/libs/controller/components/session.php read read($name = null) セッションの情報を読み込みます。 $

no image

ビルトインされたバリデーションルール

CakePHP標準で多くのバリデーションルールが搭載されています。 ソース:/cake/libs/validation.php email / maxLength / minLength /

no image

シンプルに設置できる数字Captcha「MathCaptcha」

スパム防止などで利用されているCaptchaですが、数字版で使えるものがないか探してみました。 この「MathCapthca」は非常にシンプルに設置できるのはいいですが、やっぱりクエスチョンの部分は

Cookieログイン

今回は、「keep me logged in」などログイン画面でよくみかけるクッキーログインの機能を使ってみます。 CakePHPには、Cookieコンポーネントがあります。(PHPのsetcook

フィールド単位でバリデーション無効化

save処理の際に条件付でモデルのバリデーションをフィールド単位でスキップする処理のメモです。(最終的に使うことはなかったのでメモ) 関数は unset( $this->->validate[

コントローラ内でバリデーション処理を呼び出す

通常、saveメソッドの際にバリデーション処理も自動で行われますが、save処理と切り離してバリデーションを行うこともできます。このときは、save時と若干異なる処理体系になります。 バリデーシ

Textヘルパー

Textヘルパーには、テキスト処理に関する便利な機能があります。リンク付与やテキストの抜粋・ハイライトや切り取り処理など。ソース:/cake/libs/view/helpers/text.php

no image

validateErrors と validationErrors

CakePHP試験中に気付いたことがあって、メモです。 $this->validateErrors自身バリデーション処理している 今まで、save時にバリデーションエラーメッセージををログに出力し

no image

Debugkitをインストール

CakePHPのデバッグツールとしてはデファクトスタンダードといってもいいDebugkitをインストールしました。 ダウンロード CakePHP 1.3用 https://github.com

Message

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

*

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

    PAGE TOP ↑