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

php程序访问报500错误处理方案,第1张

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

我们学习了解了这么多关于PHP的知识,不知道你们对PHP程序语法错误是否已经完全掌握了呢,如果没有,那就跟随本篇文章一起继续学习吧

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);//程序正常执行逻辑......

刚才说的场景一问题,后来我们按照上面输出到log的方式输出才发现的,是因为MysqL连接异常断开而程序继续执行(连接MysqL时正常,但当调用具体查询方法时报错,记得好像是在使用方法MysqLi_real_escape_string()的地方)导致的fatal级报错,最终才顺利修复了。

磁盘满了导致

场景二:有一次,一个同事说图片上传不上去了,一直报错500,之前还好好的,但没找出是什么问题,因为那块当时是我负责开发的,所以就过来找我,各种检查都没发现是什么问题,其它页面访问正常,本页面把代码全删除了再上传还是报错,找了很久最终才发现是磁盘满了o(╥﹏╥)o…

因磁盘空间不足,没有足够空间读写数据而导致的500报错极不常见,且不易及时发现。通常遇到500问题,很快想到的是程序错误,其实还有可能是磁盘空间不足了,如果在程序上为找到任何问题,可以查看下是否是磁盘空间不足问题哦~
df -h 查看磁盘空间占用情况

对于http请求报错状态码为500,通常解释是:表示服务器遇到错误,无法完成请求(即服务器内部错误),但具体问题还要具体分析

推荐学习:《PHP视频教程》

总结

以上是编程之家为你收集整理的php程序访问报500错误处理方案全部内容,希望文章能够帮你解决php程序访问报500错误处理方案所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/997340.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存