服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - PHP教程 - Yii2实现log输出到file及database的方法

Yii2实现log输出到file及database的方法

2021-03-23 16:59zergling9999 PHP教程

这篇文章主要介绍了Yii2实现log输出到file及database的方法,结合实例形式分析了Yii2日志输出到文件及数据库的相关设置与实现技巧,需要的朋友可以参考下

本文实例讲述了Yii2实现log输出到filedatabase的方法。分享给大家供大家参考,具体如下:

编辑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程序设计有所帮助。

延伸 · 阅读

精彩推荐