找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 253|回复: 0
打印 上一主题 下一主题

详解PHP的Yii框架中日志的相关配置及使用

[复制链接]

2536

主题

2536

帖子

7532

积分

论坛元老

Rank: 8Rank: 8

积分
7532
跳转到指定楼层
楼主
发表于 2018-2-14 05:40:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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

  
  • CDbLogRoute: 将信息保存到数据库的表中。
      
  • CEmailLogRoute: 发送信息到指定的 Email 地址。
      
  • CFileLogRoute: 保存信息到应用程序 runtime 目录中的一个文件中。
      
  • CWebLogRoute: 将 信息 显示在当前页面的底部。
      
  • CProfileLogRoute: 在页面的底部显示概述(profiling)信息。

    信息级别levels:

      
  • trace: 这是在 Yii::trace 中使用的级别。它用于在开发中 跟踪程序的执行流程。
      
  • info: 这个用于记录普通的信息。
      
  • profile: 这个是性能概述(profile)。下面马上会有更详细的说明。
      
  • warning: 这个用于警告(warning)信息。
      
  • error: 这个用于致命错误(fatal error)信息。

    分类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:EVEL_PROFILE,
        'showInFireBug' => true,
        'ignoreAjaxInFireBug' => true,
        'categories' => 'system.db.* ', //只记录db的操作日志,其他的忽略
    ),
    然后在某个controller的某个action中加入:
    Yii::beginProfile('db', 'pocketpet');
    for($i=0;$ifindByPk("1");//这里只要是数据库操作就行,这个只是个例子
    }
    Yii::endProfile('db', 'pocketpet');
    在浏览器中访问这个action,记得先打开firebug,然后firebug中就能看到如下图的记录:

    相同的query会进行归类,计算total和average,这个对于分析还是非常有帮助的。
    也可以将db的日志写到文件,配置如下(不建议使用,还是到浏览器用firebug方便):
    array(
      'class'=>'CFileLogRoute',
      'levels' => CLogger:EVEL_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语句的参数在内的信息都会记录到日志里,非常详细
      ),
    )
                
                
    您可能感兴趣的文章:
  • yii框架配置默认controller和action示例
  • Yii配置文件用法详解
  • Yii学习总结之安装配置
  • PHP的Yii框架的常用日志操作总结
  • YII Framework框架教程之日志用法详解
  • 全面解读PHP的Yii框架中的日志功能
  • Yii配置与使用memcached缓存的方法
  • yii2 数据库读写分离配置示例
  • Yii2框架中日志的使用方法分析
  • Yii框架实现记录日志到自定义文件的方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端