laravel中的錯誤與日誌

日誌

laravel中的日誌是基於monolog而封裝的。laravel在它上面作了幾個事情:php

  • 把monolog中的addInfo等函數簡化成爲了info這樣的函數
  • 增長了useFiles和useDailyFiles兩個參數,使得作日誌管理和切割變的容易了
  • 若是要調用monolog的方法須要調用callMonolog函數

好了,看下下面幾個需求怎麼實現:laravel

將不一樣的日誌信息存放到不一樣的日誌中去

這個需求很廣泛的,好比調用訂單的日誌,須要記錄到order.log,獲取店鋪信息的記錄須要記錄到shop.log中去。能夠這麼作:git

<?php 

use Monolog\Logger;
use Monolog\Handler\StreamHandler;
use Illuminate\Log\Writer;

class BLogger
{
    // 全部的LOG都要求在這裏註冊
    const LOG_ERROR = 'error';

    private static $loggers = array();

    // 獲取一個實例
    public static function getLogger($type = self::LOG_ERROR, $day = 30)
    {
        if (empty(self::$loggers[$type])) {
            self::$loggers[$type] = new Writer(new Logger($type));
            self::$loggers[$type]->useDailyFiles(storage_path().'/logs/'. $type .'.log', $day);
        }

        $log = self::$loggers[$type];
        return $log;
    }
}

這樣不一樣的日誌數據會被存儲到不一樣的日誌文件中去。還能記錄日誌數據信息。github

laravel的錯誤日誌堆棧太長了,怎麼辦?

使用上面的BLogger類,在start/global.php記錄下必要的錯誤信息sql

// 錯誤日誌信息
App::error(function(Exception $exception, $code)
{
    Log::error($exception);

    $err = [
        'message' => $exception->getMessage(),
        'file' => $exception->getFile(),
        'line' => $exception->getLine(),
        'code' => $exception->getCode(),
        'url' => Request::url(),
        'input' => Input::all(),
    ];
    BLogger::getLogger(BLogger::LOG_ERROR)->error($err);
});

laravel默認的日誌沒有使用分割

因此應該默認把laravel的默認日誌記錄改爲有分割的。數據庫

一樣在start/global.php中json

Log::useDailyFiles(storage_path().'/logs/laravel.log', 30);

如何記錄一個請求的sql日誌

這個應該再細化問,你是否是要實時記錄?服務器

若是不要實時記錄,那麼laravel有個DB::getQueryLog能夠獲取一個app請求獲取出來的sql請求:app

## 在filters.php中
App::after(function($request, $response)
{
    // 數據庫查詢進行日誌
    $queries = DB::getQueryLog();
    if (Config::get('query.log', false)) {
        BLogger::getLogger('query')->info($queries);
    }
}

若是你是須要實時記錄的(也就是你在任何地方die出來的時候,以前的頁面的sql請求也有記錄)的話,你就須要監聽illuminate.query事件了函數

// 數據庫實時請求的日誌
if (Config::get('database.log', false))
{
    Event::listen('illuminate.query', function($query, $bindings, $time, $name)
    {
        $data = compact('query','bindings', 'time', 'name');
        BLogger::getLogger(BLogger::LOG_QUERY_REAL_TIME)->info($data);
    });
}

錯誤

laravel的全部錯誤會所有過global的App::error再出來

因此好比你設計的是接口,但願即便有error出現也返回json數據,則能夠這麼作:

// 錯誤日誌信息
App::error(function(Exception $exception, $code)
{
    // 若是沒有路徑就直接跳轉到登陸頁面
    if ($exception instanceof NotFoundHttpException) {
        return Redirect::route('login');
    }

    Log::error($exception);

    $err = [
        'message' => $exception->getMessage(),
        'file' => $exception->getFile(),
        'line' => $exception->getLine(),
        'code' => $exception->getCode(),
        'url' => Request::url(),
        'input' => Input::all(),
    ];
    BLogger::getLogger(BLogger::LOG_ERROR)->error($err);

    $response = [
        'status' => 0,
        'error' => "服務器內部錯誤",
    ];
    return Response::json($response);
});

若是你還但願將404錯誤也hold住:

App::missing(function($exception)
{
    $response = [
        'status' => 0,
        'error' => "請求路徑錯誤",
    ];
    return Response::json($response);
});
相關文章
相關標籤/搜索