PHP如何记录错误和发送错误

Posted coder_up

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP如何记录错误和发送错误相关的知识,希望对你有一定的参考价值。

1. 使用 pecl extension SeasLog

1. 为什么使用SeasLog

  • 高性能 (使用C语言开发,写在缓存池中,等到达到一定量的时候一次性写入文件中,解决了频繁写入带来的速度慢的问题)
  • 无需配置
  • 功能完善,使用简单

2. install & config

pecl install seaslog
vim /usr/local/php/etc/php.ini
extension=seaslog.so

3. error type

INFO
ERROR
NOTICE
DEBUG
Alert

4. use

mkdir logpath
chmod -R 777 logpath   //Must can writeable
Seaslog::setBasePath('/home/logpath/log');
Seaslog::setLogger('guestbook');
Seaslog::log('Notice', 'this is notice log!')

5. Tips

  1. 不要在虚拟主机中使用SeasLog
  2. 不要在集群服务中使用SeasLog , 它只在单一服务器上使用比较好, 集群上面一般使用支持网络的日志系统! 如kafka( LinkedIn开源的 )
  3. Seaslog::setLogger(‘errorController’); 这里面不能有大写 应该写成errorcontroller
  4. 如果想使用analyzerDetail 分析错误日志, 必须关掉php.ini中的: seaslog.disting_type = 0 ;是否以type分文件 1是 0否(默认

2. php自带的功能

1. 将错误记录到指定的文件中,配置过程如下

log_errors=on
error_log=/tmp/php_error.log

header('content-type:text/html; charset=utf-8');
//开启所有的错误报告
error_reporting(-1);
//设置时区
ini_set('date.timezone', 'PRC');
//禁用页面显示错误
ini_set('display_errors', 0);
//开启日志记录功能
ini_set('log_errors', 1);
//设置错误日志保存的位置
ini_set('error_log', '/tmp/custom_error.log');
//忽略重复的错误
ini_set('ignore_repeated_errors', 'on');
//忽略重复的错误来源
ini_set('ignore_repeated_source', 'on');

error_log('我要把你记录到我的自定义错误日志中'.date('Y-m-d H:i:s', time()));
trigger_error('trigger_error-----我要把你记录到我的系统错误日志中'.date('Y-m-d H:i:s', time()), E_USER_NOTICE);

2.将错误记录到系统日志中

常用: ini_set('error_log', 'syslog');

方法一
//开启所有的错误报告
error_reporting(-1);
//禁用页面显示错误
ini_set('display_errors', 0);
//开启日志记录功能
ini_set('log_errors', 1);
//设置错误日志保存的位置------(系统日志)
ini_set('error_log', 'syslog');
//忽略重复的错误
ini_set('ignore_repeated_errors', 'on');
//忽略重复的错误来源
ini_set('ignore_repeated_source', 'on');

// error_log('error_log-----我要把你记录到我的系统错误日志中'.date('Y-m-d H:i:s', time()));
trigger_error('trigger_error-----我要把你记录到我的系统错误日志中'.date('Y-m-d H:i:s', time()), E_USER_NOTICE);

方法二
//====================出于安全问题不用===========================
//打开到系统日志的链接
openlog('PHP5.6.0', LOG_PID, LOG_SYSLOG);
syslog(LOG_ERR, 'this is a test syslog'.date('Y-m-d H:i:s', time()));
closelog();

3.将错误日志通过邮件发送

  • 1.error_log('msg', 1, mail_addr); 第二个参数设置为1
    ** bool error_log ( string $message [, int $message_type = 0 [, string $destination [, string $extra_headers ]]] )
message
应该被记录的错误信息。

message_type
设置错误应该发送到何处。可能的信息类型有以下几个:

error_log() 日志类型
0   message 发送到 PHP 的系统日志,使用 操作系统的日志机制或者一个文件,取决于 error_log 指令设置了什么。 这是个默认的选项。
1   message 发送到参数 destination 设置的邮件地址。 第四个参数 extra_headers 只有在这个类型里才会被用到。
2   不再是一个选项。
3   message 被发送到位置为 destination 的文件里。 字符 message 不会默认被当做新的一行。
4   message 直接发送到 SAPI 的日志处理程序中。
destination
目标。它的含义描述于以上,由 message_type 参数所决定。

extra_headers
额外的头。当 message_type 设置为 1 的时候使用。 该信息类型使用了 mail() 的同一个内置函数。
//开启所有的错误报告
error_reporting(-1);
//禁用页面显示错误
ini_set('display_errors', 0);
//开启日志记录功能
ini_set('log_errors', 1);
//忽略重复的错误
ini_set('ignore_repeated_errors', 'on');
//忽略重复的错误来源
ini_set('ignore_repeated_source', 'on');

//设置第二个参数为1将,使用邮件发送错误日志信息
error_log('error_log-----我要把你记录到我的系统错误日志中'.date('Y-m-d H:i:s', time()), 1, '732578448@qq.com');

以上是关于PHP如何记录错误和发送错误的主要内容,如果未能解决你的问题,请参考以下文章

如何修复 PHP 中的“标头已发送”错误

如何修复 PHP 中的“标头已发送”错误

如何修复 PHP 中的“标头已发送”错误

如何解决使用php发送邮件的错误

如何在 AWS Elastic Beanstalk Docker 容器中记录 PHP 错误

如何使用 PHP 处理 403 错误