Yii-로깅

Yii는 고도로 사용자 정의 가능하고 확장 가능한 프레임 워크를 제공합니다. 이 프레임 워크의 도움으로 다양한 유형의 메시지를 쉽게 기록 할 수 있습니다.

메시지를 기록하려면 다음 메소드 중 하나를 호출해야합니다.

  • Yii::error() − 치명적인 오류 메시지를 기록합니다.

  • Yii::warning() − 경고 메시지를 기록합니다.

  • Yii::info() − 유용한 정보와 함께 메시지를 녹음합니다.

  • Yii::trace() − 코드가 어떻게 실행되는지 추적하기 위해 메시지를 기록합니다.

위의 방법은 다양한 범주에서 로그 메시지를 기록합니다. 그들은 다음 함수 서명을 공유합니다-

function ($message, $category = 'application')

어디서-

  • $message − 기록 할 로그 메시지

  • $category − 로그 메시지의 카테고리

이름 지정 체계의 간단하고 편리한 방법은 PHP __METHOD__ 매직 상수를 사용하는 것입니다. 예를 들면-

Yii::info('this is a log message', __METHOD__);

로그 대상은 yii \ log \ Target 클래스의 인스턴스입니다. 모든 로그 메시지를 범주별로 필터링하고 파일, 데이터베이스 및 / 또는 이메일로 내 보냅니다.

Step 1 − 마찬가지로 여러 로그 대상을 등록 할 수 있습니다.

return [
   // the "log" component is loaded during bootstrapping time
   'bootstrap' => ['log'],
   'components' => [
      'log' => [
         'targets' => [
            [
               'class' => 'yii\log\DbTarget',
               'levels' => ['error', 'warning', 'trace', 'info'],
            ],
            [
               'class' => 'yii\log\EmailTarget',
               'levels' => ['error', 'warning'],
               'categories' => ['yii\db\*'],
               'message' => [
                  'from' => ['[email protected]'],
                  'to' => ['[email protected]', '[email protected]'],
                  'subject' => 'Application errors at mydomain.com',
               ],
            ],
         ],
      ],
   ],
];

위 코드에서는 두 개의 타겟이 등록되어 있습니다. 첫 번째 대상은 모든 오류, 경고, 추적 및 정보 메시지를 선택하여 데이터베이스에 저장합니다. 두 번째 대상은 모든 오류 및 경고 메시지를 관리자 이메일로 보냅니다.

Yii는 다음과 같은 내장 로그 대상을 제공합니다.

  • yii\log\DbTarget − 데이터베이스에 로그 메시지를 저장합니다.

  • yii\log\FileTarget − 로그 메시지를 파일로 저장합니다.

  • yii\log\EmailTarget − 미리 정의 된 이메일 주소로 로그 메시지를 보냅니다.

  • yii\log\SyslogTarget − PHP 함수 syslog ()를 호출하여 로그 메시지를 syslog에 저장합니다.

기본적으로 로그 메시지는 다음과 같이 형식화됩니다.

Timestamp [IP address][User ID][Session ID][Severity Level][Category] Message Text

Step 2 −이 형식을 사용자 지정하려면 yii\log\Target::$prefix특성. 예를 들면.

[
   'class' => 'yii\log\FileTarget',
   'prefix' => function ($message) {
      $user = Yii::$app->has('user', true) ? Yii::$app->get('user') : 'undefined user'; $userID = $user ? $user->getId(false) : 'anonym';
      return "[$userID]";
   }
]

위의 코드 조각은 모든 로그 메시지에 현재 사용자 ID를 접두사로 지정하도록 로그 대상을 구성합니다.

기본적으로 로그 메시지에는 다음 전역 PHP 변수의 값이 포함됩니다. $ _GET, $_POST, $_세션, $_COOKIE, $_FILES 및 $ _SERVER. 이 동작을 수정하려면 다음을 구성해야합니다.yii\log\Target::$logVars 포함 할 변수의 이름이있는 속성.

모든 로그 메시지는 로거 개체에 의해 배열로 유지됩니다. 로거 개체는 어레이가 특정 수의 메시지를 누적 할 때마다 기록 된 메시지를 로그 대상에 플러시했습니다 (기본값은 1000).

Step 3 −이 번호를 사용자 지정하려면 flushInterval property.

return [
   'bootstrap' => ['log'],
   'components' => [
      'log' => [
         'flushInterval' => 50, // default is 1000
         'targets' => [...],
      ],
   ],
];

로거 개체가 로그 메시지를 로그 대상으로 플러시하더라도 즉시 내보내지는 않습니다. 로그 대상에 일정 수의 메시지 (기본값 : 1000)가 누적되면 내보내기가 수행됩니다.

Step 4 −이 번호를 사용자 지정하려면 exportInterval 특성.

[
   'class' => 'yii\log\FileTarget',
   'exportInterval' => 50, // default is 1000
]

Step 5 − 이제 config/web.php 이 방법으로 파일을 작성하십시오.

<?php
   $params = require(__DIR__ . '/params.php'); $config = [
      'id' => 'basic',
      'basePath' => dirname(__DIR__),
      'bootstrap' => ['log'],
      'components' => [
         'request' => [
            // !!! insert a secret key in the following (if it is empty) - this
               //is required by cookie validation
            'cookieValidationKey' => 'ymoaYrebZHa8gURuolioHGlK8fLXCKjO',
         ],
         'cache' => [
            'class' => 'yii\caching\FileCache',
         ],
         'user' => [
            'identityClass' => 'app\models\User',
            'enableAutoLogin' => true,
         ],
         'errorHandler' => [
            'errorAction' => 'site/error',
         ],
         'mailer' => [
            'class' => 'yii\swiftmailer\Mailer',
            // send all mails to a file by default. You have to set
            // 'useFileTransport' to false and configure a transport
            // for the mailer to send real emails.
            'useFileTransport' => true,
         ],
         'log' => [
            'flushInterval' => 1,
            'traceLevel' => YII_DEBUG ? 3 : 0,
            'targets' => [
               [
                  'class' => 'yii\log\FileTarget',
                  'exportInterval' => 1,
                  'logVars' => []
               ],
            ],
         ],
         'db' => require(__DIR__ . '/db.php'),
      ],
      'modules' => [
         'hello' => [
            'class' => 'app\modules\hello\Hello',
         ],
      ],
      'params' => $params, ]; if (YII_ENV_DEV) { // configuration adjustments for 'dev' environment $config['bootstrap'][] = 'debug';
      $config['modules']['debug'] = [ 'class' => 'yii\debug\Module', ]; $config['bootstrap'][] = 'gii';
      $config['modules']['gii'] = [ 'class' => 'yii\gii\Module', ]; } return $config;
?>

위의 코드에서 로그 애플리케이션 구성 요소를 정의하고 flushIntervalexportInteval모든 로그 메시지가 로그 파일에 즉시 표시되도록 속성을 1로 설정합니다. 로그 대상의 levels 속성도 생략합니다. 이는 모든 범주 (오류, 경고, 정보, 추적)의 로그 메시지가 로그 파일에 표시됨을 의미합니다.

Step 6 − 그런 다음 SiteController에 actionLog ()라는 함수를 생성합니다.

public function actionLog() {
   Yii::trace('trace log message');
   Yii::info('info log message');
   Yii::warning('warning log message');
   Yii::error('error log message');
}

위의 코드에서 우리는 다른 범주의 4 개의 로그 메시지를 로그 파일에 작성합니다.

Step 7 − URL 입력 http://localhost:8080/index.php?r=site/log웹 브라우저의 주소 표시 줄에서. 로그 메시지는 app.log 파일의 app / runtime / logs 디렉토리에 표시되어야합니다.