ログローテーション

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));
  • このエントリーをはてなブックマークに追加

関連記事

Cookieログイン

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

no image

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

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

no image

Secutiryユーティリティ

CakePHPでは、データのハッシュ化もしくは暗号化のためのメソッドSecurityユーティリティが用意されています。 ソース: /cake/libs/security.php Security:

no image

Sessionコンポーネント

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

no image

Jsヘルパーを使用してAjax更新

更新処理でページ遷移を伴う場合、ページ全体をレスポンスするのに対して、Ajax処理ではページの一部のレスポンスが可能となるためサーバからの通信量を抑えることが可能となります。 Jsヘルパーを使用して

複数ファイルアップロード

CakePHPで複数ファイルのアップロードについて調べてみました。といっても普通のPHPのコードと同じではありますが、postするフィールド名に[]を付与して配列にします。 view

CakePHP 1.3 インストール

使い古されている手ではありますが、表題の件とレンタルサーバへの配置方法などにも使えますので参考にしていただけたらと思います。 まずはレンタルサーバでCakePHPを動作させる CakePHPア

no image

Debugkitをインストール

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

no image

validateErrors と validationErrors

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

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

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

Message

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

*

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

    PAGE TOP ↑