zoukankan      html  css  js  c++  java
  • 关于ThinkPHP5.1+的Log无法记录SQL调试记录的小经历

      项目开发阶段,除了基本编码外,性能也需要实时关注与优化。之前我的大部分项目都是使用ThinkPHP5.0以及ThinkPHP3.2,对于框架提供的日志记录和日志配置都差不多,然后使用ThinkPHP5.1的时候就吃瘪,花了十几分钟才好,所以写一下防止后面忘记了再踩坑。

    日志配置

    ThinkPHP5.1没有了config.php,日志配置单独提出来自成一块,叫Log.php,这个适应一下就可以。

    日志记录

    在5.1以前的项目中记录个人调试的日志,都是使用use thinkLog; 然后使用Log::write()。然后5.1的时候引入了facede,所以直接用以前的方式,不能使用静态调用write等方法,修改为use thinkfacedeLog,然后再使用。

     

    实际日志配置

    当需要调试时,app配置中'app_debug' => true, 'app_trace'      => true, 调试和追踪开启,浏览器打开会右下角出现TP的logo和运行时间,点击图标会出现调试明细。

    但是有时不会出现,但是想调试SQL以及SQL的查询速度,就需要开启日志记录,尽量不要配置保存目录,默认在runtime下就可以,也不是因为自定义目录的写入权限问题,所以一切默认就好,先解决问题后面再研究问题原因,Log.php配置如下。

    return [
        // 日志记录方式,支持 file socket 或者自定义驱动类
        'type' => 'File',
        'file_size'     =>2097152,
    	'apart_level' => ['sql','error'],
        //日志的时间格式,默认是` c `
        'time_format'   =>'c'
    ];

    当开发阶段结束,不需要除了error以外级别的日志,可以在"apart_level"配置只保留"error"。

  • 相关阅读:
    MS SqlServer学习笔记(索引)
    Angular动态注册组件(controller,service...)
    如何成功发布一个MSMQ的Windows服务
    主流Web服务器一览
    .NET 创建Windows服务,及服务的安装卸载
    SQL Server 查询时间段内数据
    委托和事件
    类中实现 Dispose And Finalize
    使用 ODBC .NET 提供程序和 Visual C# .NET 执行 SQL 参数化存储过程
    Windows Form 中快捷键设置
  • 原文地址:https://www.cnblogs.com/zerofc/p/11399698.html
Copyright © 2011-2022 走看看