欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

PHP生产环境的bug如何优雅地debug?

程序员文章站 2022-06-07 13:56:02
...
一直很苦恼地一个问题,有些bug只能在生产环境中重现,但是我又不能在线上放置类似echo $test;之类地代码来调试,不知道大家有没有好地经验可以分享。

回复内容:

一直很苦恼地一个问题,有些bug只能在生产环境中重现,但是我又不能在线上放置类似echo $test;之类地代码来调试,不知道大家有没有好地经验可以分享。

使用 socketlog

生产环境热调试没什么不对的,但热调试过程中暴露代码逻辑和调试数据可是大大的作死。千万不能培养自己这个习惯。

正确的方法是使用monolog等日志工具,记录你希望跟踪的信息。你可以使用额外querystring等方法约束日志记录的行为。

当然也可以专门建立一个/test一类的测试路由,然后用权限控制禁止访客进入…不够优雅就是了。

trigger_error(var_export($var,true));
然后去php错误日志里面去查

你设置一个DEBUG_COOKIE=true, 然后要调试的时候改一下你浏览器的cookie..
然后你把调试输出放到日志文件里面,就能查看了. 而且不会影响外网的呈现.

类似于 飞侠 的答案,不过我使用的是

error_log(var_export($data, true));

也可以修改该函数的第二个参数,将你要打印的信息写到指定的文件里。

最佳答案:php-console

https://github.com/barbushin/php-console

我常用做法可以就下面这样,当然里面的条件可变

if ( 'debug' == $_GET['status'] ) {
    echo $test;
}

这样是有点困难。楼上的是好办法,还没用过

像一楼说的使用socketLog,xdebug,xhprof都不错的。

使用docker构建环境,使得本地开发调试拥有一个和服务器相同的环境,调试时连使用生产环境数据库的备份创建的测试数据库

ChromePHP::log();

自己写了一个日志记录的类,在需要调试的地方加日志代码,就可以了

线上的简单调试输出, 可以把信息输出到文件吧。

相关标签: php