默认的日志是输出到protected/runtime/application.log
如果需要修改那么需要在main.PHP里面的 components 下面增加log配置,如下:
'components' => array(
'log'=>array(
'class'=>'CLogRouter','routes'=>array(
//这是一个文件route表示category为test开头的所有类型的输出都会记录到runtime/test.log下面
array(
'class'=>'CFileLogRoute','levels'=>'trace,info,debug,warn,error,fatal,profile','categories'=>'test.*','maxFileSize'=>1048576,//单文件最大1G
'logFile'=>'test.log',),//
// 开发过程中所有日志直接输出到浏览器了,这样不需要登录服务器看日志了
array(
'class' => 'CWebLogRoute','categories' => 'test.*','levels' => CLogger::LEVEL_PROFILE,'showInFireBug' => true,'ignoreAjaxInFireBug' => true,array(
'class' => 'CWebLogRoute','categories' => 'test.* ',array(
'class'=>'CEmailLogRoute','levels'=>'error,warning','emails'=>'admin@example.com',</pre>
这个log首先被记录在了内存中一个CLogger类的array中,然后会逐一的判断每个LogRoute,判断是否需要输出,注意是逐一判断,不是其中一个输出下一个就不管了。
拿上面的配置来说:
第一个CFileLogRoute,'categories'=>'test.*',levels里包含了info,test.xx满足条件,所以会执行,将这条log输出到test.log中,然后下一个CWebLogRoute, 'levels' => CLogger::LEVEL_PROFILE,。而这条log是info的,所以不会执行,再下一个CWebLogRoute,'categories' => 'test.* ',levels没指定,那就说不过滤,所以这个也会被执行,所以这条log将被输出到浏览器中。
二、profile功能
另外logger还有一个很强大的功能:profile,这样就能测试这个code block的执行效率了,非常的方便啊。
更详细的配置查看:http://www.yiiframework.com/doc/api/1.1/CProfileLogRoute
然后还有一个很BUG的功能,Profiling sql Executions
很多时候sql语句写的不好会非常影响效率的,但是要确定哪一条语句影响了效率就需要profiling了。YII也提供了这个bug级别的功能。
三、Yii::log()和Yii::trace()的使用
首先在config文件中设置log日志路由class:
- CDbLogRoute: 将信息保存到数据库的表中。
- CEmailLogRoute: 发送信息到指定的 Email 地址。
- CFileLogRoute: 保存信息到应用程序 runtime 目录中的一个文件中。
- CWebLogRoute: 将 信息 显示在当前页面的底部。
- CProfileLogRoute: 在页面的底部显示概述(profiling)信息。
信息级别levels:
- trace: 这是在 Yii::trace 中使用的级别。它用于在开发中 跟踪程序的执行流程。
- info: 这个用于记录普通的信息。
- profile: 这个是性能概述(profile)。下面马上会有更详细的说明。
- warning: 这个用于警告(warning)信息。
- error: 这个用于致命错误(fatal error)信息。
分类categories:
可以自定义,但在输出函数里要对应才会被写入日志里 (例如上边写的是 cool.* 和 system.db.* ,就会把相应分类的信息写入日志,请结合下文来理解)
设置完了,就可以用写入日志的函数来记录了:
trace()和log()的区别: trace()只会在调试模式下生效,即开启debug的时候 trace()不分level,但log()能设置levels参数
四、调试sql query每个语句执行的耗时
在配置中的log下加上下面这个Route然后在某个controller的某个action中加入:
Yii::endProfile('db','pocketpet');
在浏览器中访问这个action,记得先打开firebug,然后firebug中就能看到如下图的记录:
相同的query会进行归类,计算total和average,这个对于分析还是非常有帮助的。
也可以将db的日志写到文件,配置如下(不建议使用,还是到浏览器用firebug方便):
当然,想要生效还得有下面两步配置:
1 . 记得在index.PHP,中加入以下配置
defined('YII_DEBUG_SHOW_PROFILER') or define('YII_DEBUG_SHOW_PROFILER',true);
//enable profiling
defined('YII_DEBUG_PROFILING') or define('YII_DEBUG_PROFILING',true);
//trace level
defined('YII_TRACE_LEVEL') or define('YII_TRACE_LEVEL',3);
//execution time
defined('YII_DEBUG_DISPLAY_TIME') or define('YII_DEBUG_DISPLAY_TIME',false);
require_once($yii);
Yii::createWebApplication($config)->run();