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;
?>
위의 코드에서 로그 애플리케이션 구성 요소를 정의하고 flushInterval 과 exportInteval모든 로그 메시지가 로그 파일에 즉시 표시되도록 속성을 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 디렉토리에 표시되어야합니다.