• 欢迎访问极客公园网站,WordPress信息,WordPress教程,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站,欢迎加入极客公园 QQ群
  • Git主题现已支持滚动公告栏功能,兼容其他浏览器,看到的就是咯,在后台最新消息那里用li标签添加即可。
  • 最新版Git主题已支持说说碎语功能,可像添加文章一样直接添加说说,新建说说页面即可,最后重新保存固定连接,演示地址
  • 百度口碑求点赞啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊http://koubei.baidu.com/s/gitcafe.net
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏极客公园吧

php程序访问报500错误处理方案

编程技术 my2foulive 8个月前 (12-30) 233次浏览

对于http请求报错状态码为500,通常解释是:表示服务器遇到错误,无法完成请求(即服务器内部错误),但具体问题还要具体分析,下面说下我遇到过的一些500问题及处理方案

PHP程序语法错误导致

场景一:我们项目设置有报警监控(定时每隔10分钟访问一下网站的一个固定链接),曾经有段时间,每天都会收到两三次报500错误的邮件,但当自己再手动访问时却访问正常…

这应该是最常见的错误了,语法错误也能很快复现,只要把报错信息暴露出来即可根据问题立马解决。
如果是在本地或测试环境,通常我们是这么处理的,在程序入口中设置输出报错信息即可:

//error_reporting设置应该报告的错误,下面表示除了 E_NOTICE,报告其他所有错误
error_reporting(E_ALL ^ E_NOTICE);
//输出错误
ini_set('display_errors', 1);

但在线上环境的话,因为用户都在用,不可能允许我们就那么赤裸裸的打印错误,怎么办呢?可以在程序入口文件中设置将错误输出到日志文件中,具体代码如下:

error_reporting(E_ALL ^ E_NOTICE);
//禁止把错误输出到页面
ini_set('display_errors', 0);
//设置错误信息输出到文件
ini_set('log_errors', 1);

//指定错误日志文件名
$error_dir = '/logs/err/';
$error_file = $error_dir . date('Ymd').'.log';
//目录不存在就创建
if (!is_dir($error_dir)){
    mkdir($error_dir, 0777, true);
}
//文件不存在就创建之
if(!file_exists($error_file)){
    $fp = fopen($error_file, 'w+');
    if($fp){
        fclose($fp);
    }
}

//设置错误输出文件
ini_set("error_log", $error_file);

//程序正常执行逻辑......

[30-Dec-2018 10:37:01 Asia/Chongqing] PHP Fatal error: Uncaught exception ‘Exception’ with message ‘MySQL Error: Disk full (/var/tmp/#sql_f51_0); waiting for someone to free some space…’ in /home/admin/web/vr.tjview.com/public_html/source/include/cls_db.php:373

主要错误是 Disk full (/var/tmp/#sql_f51_0); waiting for someone to free some space…

磁盘满了导致

使用df -h 磁盘空间不足,使用了100%,所以无法进行数据库修改和插入。

参考
https://blog.csdn.net/huohuanyu1/article/details/84680116


极客公园 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php程序访问报500错误处理方案
喜欢 (0)