默认的日志是输出到protected/runtime/application.log
如果需要修改那么需要在main.php里面的 components 下面增加log配置,如下:
\'preload\' => array(\'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\', ), ), ), ),
这个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,
Yii::beginProfile(\'blockID\'); ...code block being profiled... Yii::endProfile(\'blockID\');
这样就能测试这个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
\'log\'=>array( \'class\'=>\'CLogRouter\', \'routes\'=>array( array( \'class\'=>\'CFileLogRoute\',//这表示把日志输出到文件中,下方有详细的 \'levels\'=>\'error, warning\', ), array( \'class\'=>\'CWebLogRoute\',//这表示把日志显示在网页下方,下方有详细的 \'levels\'=>\'trace, info, error, warning\', \'categories\'=>\'cool.*,system.db.*\', ), ), ),
日志路由class:
信息级别levels:
分类categories:
可以自定义,但在输出函数里要对应才会被写入日志里
(例如上边写的是 cool.* 和 system.db.* ,就会把相应分类的信息写入日志,请结合下文来理解)
设置完了,就可以用写入日志的函数来记录了:
Yii::trace(\'My log message.\',\'cool.pd\'); //cool.pd属于cool.*分类,所以会被写入日志 Yii::log(\'My log message.\',\'info\',\'cool.collectpd\'); //log定义级别为info,结合上文,第一个logclass会忽略,不会被写入文件,但会被第二个logclass接收,写入日志在网络下方显示。
trace()和log()的区别:
trace()只会在调试模式下生效,即开启debug的时候
trace()不分level,但log()能设置levels参数
四、调试sql query每个语句执行的耗时
在配置中的log下加上下面这个Route
//这个配置专门负责数据库操作的profile array( \'class\'=>\'CProfileLogRoute\', \'levels\' => CLogger::LEVEL_PROFILE, \'showInFireBug\' => true, \'ignoreAjaxInFireBug\' => true, \'categories\' => \'system.db.* \', //只记录db的操作日志,其他的忽略 ),
然后在某个controller的某个action中加入:
Yii::beginProfile(\'db\', \'pocketpet\'); for($i=0;$i<1000;$i++){ $user = UserModel::model()->findByPk(\"1\");//这里只要是数据库操作就行,这个只是个例子 }
Yii::endProfile(\'db\', \'pocketpet\');
在浏览器中访问这个action,记得先打开firebug,然后firebug中就能看到如下图的记录:
相同的query会进行归类,计算total和average,这个对于分析还是非常有帮助的。
也可以将db的日志写到文件,配置如下(不建议使用,还是到浏览器用firebug方便):
array( \'class\'=>\'CFileLogRoute\', \'levels\' => CLogger::LEVEL_PROFILE, \'categories\' => \'system.db.* \', //只记录db的操作日志,其他的忽略 \'logFile\'=>\'db.log\', ),
当然,想要生效还得有下面两步配置:
1 . 记得在index.php, 中加入以下配置
$yii = dirname(__FILE__).\'/../yii/framework/yii.php\'; $config = dirname(__FILE__).\'/protected/config/main.php\'; defined(\'YII_DEBUG\') or define(\'YII_DEBUG\',true); 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();
2. 在main.php主配置文件里面,的components db 里将enableProfiling设置为true
\'components\' => array( \'db\' => array( \'enableProfiling\' => true, //这个是用来记录日志的,会记录每一条语句执行的时间 \'enableParamLogging\' => true,//true表示包括sql语句的参数在内的信息都会记录到日志里,非常详细 ), )
本文地址:https://www.stayed.cn/item/26154
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我