详解PHP的Yii框架中日志的相关配置及使用
php  /  管理员 发布于 8年前   231
默认的日志是输出到protected/runtime/application.log 如果需要修改那么需要在main.php里面的 components 下面增加log配置,如下: 这个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功能 这样就能测试这个code block的执行效率了,非常的方便啊。 更详细的配置查看:http://www.yiiframework.com/doc/api/1.1/CProfileLogRoute 然后还有一个很BUG的功能,Profiling SQL Executions 很多时候sql语句写的不好会非常影响效率的,但是要确定哪一条语句影响了效率就需要profiling了。YII也提供了这个bug级别的功能。 三、Yii::log()和Yii::trace()的使用 信息级别levels: 分类categories: 可以自定义,但在输出函数里要对应才会被写入日志里 设置完了,就可以用写入日志的函数来记录了: 然后在某个controller的某个action中加入: Yii::endProfile('db', 'pocketpet'); 在浏览器中访问这个action,记得先打开firebug,然后firebug中就能看到如下图的记录: 相同的query会进行归类,计算total和average,这个对于分析还是非常有帮助的。 也可以将db的日志写到文件,配置如下(不建议使用,还是到浏览器用firebug方便): 当然,想要生效还得有下面两步配置: 1 . 记得在index.php, 中加入以下配置 2. 在main.php主配置文件里面,的components db 里将enableProfiling设置为true'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'=>'[email protected]', ), ), ), ),如果在某处调用了Yii::log("jdkshgds","info",'test.xx');
另外logger还有一个很强大的功能:profile,Yii::beginProfile('blockID');...code block being profiled...Yii::endProfile('blockID');
首先在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:
(例如上边写的是 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的操作日志,其他的忽略 ),
Yii::beginProfile('db', 'pocketpet'); for($i=0;$i<1000;$i++){ $user = UserModel::model()->findByPk("1");//这里只要是数据库操作就行,这个只是个例子 }array( 'class'=>'CFileLogRoute', 'levels' => CLogger::LEVEL_PROFILE, 'categories' => 'system.db.* ', //只记录db的操作日志,其他的忽略 'logFile'=>'db.log', ),
$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 profilingdefined('YII_DEBUG_PROFILING') or define('YII_DEBUG_PROFILING',true);//trace leveldefined('YII_TRACE_LEVEL') or define('YII_TRACE_LEVEL',3);//execution timedefined('YII_DEBUG_DISPLAY_TIME') or define('YII_DEBUG_DISPLAY_TIME',false);require_once($yii);Yii::createWebApplication($config)->run();'components' => array('db' => array( 'enableProfiling' => true, //这个是用来记录日志的,会记录每一条语句执行的时间 'enableParamLogging' => true,//true表示包括sql语句的参数在内的信息都会记录到日志里,非常详细 ),)您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号
