php日志分析
1. ubuntu下怎么查看php网站的运行日志。
PHP是不写日志的,你可以查看WEB服务器的日志,具体方法与你使用的WEB服务器软件有关,如果是apache,那么在logs目录下有error、access等文件,那就是日志,可以查看内容。
2. php日志类
首先,你得有一个“日志类”,明显PHP并没有内置,所以你需要自己编写这个类。
日志模块的大概设计思路如下:
1、你得有一个数据表,记录所有的用户行为。
2、你得写一个“日志类”,这个类至少有一个方法:向数据表写入日志信息
那日志信息从哪里来呢?
在你想记录日志的地方,调用日志类的方法来触发写入动作。
比如(伪代码):
if(用户登录成功){
$日志类=new日志类();
$日志类->插入数据("登录日志","登录成功","username=a;password=b","IP"...)
}
如果你想做日志的查询功能,显然你要给日志类加更多方法..
3. 怎么让php打印错误日志
这个得需要在php.ini里面配置开启错误日志,并且设置错误日志的保存路径。
4. PHP自带的日志是怎么写入和查看的呢
查看PHP错误日志
可以在命令行里面输入: find . -name error.log
tailf -f error.log
写入日志,有固定的函数error_log($str, 3, filename)
5. thinkphp日志记录文件被存在了什么地方
日志记录\ThinkPHP\Lib\Think\Core\Log.class.php
1、可以在config.php中进行设置,默认为关闭状态。 'APP_DEBUG' => true
打开\ThinkPHP\Common\debug.php文件可以查看debug的默认设置如下:
return array(
'LOG_RECORD'=>true, // 进行日志记录
'LOG_RECORD_LEVEL' => array('EMERG','ALERT','CRIT','ERR','WARN','NOTIC','INFO','DEBUG','SQL'), // 允许记录的日志级别
'DB_FIELDS_CACHE'=> false, //数据库字段缓存
'SHOW_RUN_TIME'=>true, // 运行时间显示
'SHOW_ADV_TIME'=>true, // 显示详细的运行时间
'SHOW_DB_TIMES'=>true, // 显示数据库查询和写入次数
'SHOW_CACHE_TIMES'=>true, // 显示缓存操作次数
'SHOW_USE_MEM'=>true, // 显示内存开销
'SHOW_PAGE_TRACE'=>true, // 显示页面Trace信息 由Trace文件定义和Action操作赋值
'APP_FILE_CASE' => true, // 是否检查文件的大小写 对Windows平台有效
);
注意事项:DB_FIELDS_CACHE数据库字段缓存默认关闭状态,如果开启的话,会在Runtime\Data文件夹下生成文件缓存,并且修改表之后,如新加了字段,这个缓存无法记录你的操作,需要我们手动删除一次,对表的修改才会成功。
将'APP_DEBUG' => true后,访问页面会出现如下图的DEBUG提示:
如果只想显示一部分提示信息,如运行时间,内存开销等,
可以在config.php中进行相应的设置即可,如:
//'APP_DEBUG' => true, // 调试模式开关
'SHOW_RUN_TIME' => true, //运行时间显示
'SHOW_ADV_TIME' => true, //显示详细的运行时间
'SHOW_DB_TIMES' => true, //显示数据库的操作次数
'SHOW_CACHE_TIMES'=>true, //显示缓存操作次数
'SHOW_USE_MEM' => true, //显示内存开销
提示信息如下图:
2、页面Trace信息的自定义:\ThinkPHP\Tpl\PageTrace.tpl.php
自定义的方法一:在config.php的同级目录加上一个trace.php文件
<?php
return array{
'当前的server信息'=>$_SERVER['REMOTE_ADDR'],
};
?>
自定义的方法二:在Action方法中添加
$this->trace('我很丑,但是我很温柔','514');
3、输出调试法:
halt('aaaaaaa');//输出aaaaaa并且中断程序执行
4、模型调试:显示SQL语句
$User=new Model('User');
$User->find(1);
echo $User->getLastSql();//输出最后执行的一条SQL语句
5、日志记录\ThinkPHP\Lib\Think\Core\Log.class.php
config.php中设置
'LOG_RECORD'=>true,//开启了日志记录
'LOG_RECORD_LEVEL'=>array('EMERG','ALERT'