一、基本日志功能

默认的日志是输出到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', 

                ), 

            ), 

        ), 

  

    ),

=========================================================================

如果在某处调用了Yii::log("jdkshgds","info",'test.xx');

这个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的执行效率了,非常的方便啊。

然后还有一个很BUG的功能,Profiling SQL Executions

很多时候sql语句写的不好会非常影响效率的,但是要确定哪一条语句影响了效率就需要profiling了。YII也提供了这个bug级别的功能

三、BUG级功能:调试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);

defined('YII_DEBUG_PROFILING') or define('YII_DEBUG_PROFILING',true);

defined('YII_TRACE_LEVEL') or define('YII_TRACE_LEVEL',3);

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语句的参数在内的信息都会记录到日志里,非常详细

    ),

=========================================================================

)

四、调用示例

=========================================================================

Yii::log("dfdf",CLogger::LEVEL_INFO,"example"); 

Yii::log("dfdf",CLogger::LEVEL_INFO,"example"); 

Yii::log("dfdf",CLogger::LEVEL_ERROR,"example"); 

Yii::trace("dfdf", "example"); 

Yii::trace('example trace message', 'example'); 

Yii::log('info', CLogger::LEVEL_INFO, 'example'); 

Yii::log('error', CLogger::LEVEL_ERROR, 'example'); 

Yii::log('trace', CLogger::LEVEL_TRACE, 'example'); 

Yii::log('warning', CLogger::LEVEL_WARNING, 'example'); 

Yii::beginProfile('db', 'example'); 

for($i=0;$i<1000;$i++){ 

    $user = UserModel::model()->findByPk("1"); 

Yii::endProfile('db', 'example'); 

echo 'done';

=========================================================================