本文實例講述了Yii2實現log輸出到file及database的方法。分享給大家供大家參考,具體如下:
編輯config/web.php
首先log要開啟
1
2
3
|
'bootstrap' => [ 'log' ], |
[file]
1
2
3
4
5
6
7
8
9
10
|
'components' => [ 'log' => [ 'targets' => [ [ 'class' => 'yii\log\FileTarget' , 'exportInterval' => 1, ], ], ], ] |
默認輸出到runtime/logs/app.log
注意webserver或控制臺用戶要有寫入該文件的權限
[database]
1
2
3
4
5
6
7
8
|
'log' => [ 'targets' => [ [ 'class' => 'yii\log\DbTarget' , 'levels' => [ 'error' , 'warning' , 'trace' ], ] ] ], |
默認輸出db組件對應的數據庫下{{%log}}表
yii2根目錄下運行下面命令生成對應的table schema
1
|
. /yii migrate --migrationPath=@yii /log/migrations/ |
注意config/console.php下也要有和web.php同樣的配置,否則命令執行不成功。
還可以根據不同的環境配置不同的日志模式
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
'components' => [ 'log' => [ 'traceLevel' => YII_ENV == 'dev' ? 3 : 0, 'targets' => [ [ 'class' => 'yii\log\DbTarget' , 'levels' => YII_DEBUG ? [ 'error' , 'warning' , 'trace' ] : [ 'error' ], ], [ 'class' => 'yii\log\FileTarget' , 'levels' => YII_DEBUG ? [ 'error' , 'warning' , 'trace' ] : [ 'error' , 'warning' ], ], ], ], ], |
希望本文所述對大家基于Yii框架的PHP程序設計有所幫助。