PHP生产环境的bug如何优雅地debug?
巴扎黑
巴扎黑 2017-04-10 15:05:37
[PHP讨论组]

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

巴扎黑
巴扎黑

全部回复(13)
PHP中文网

使用 socketlog

巴扎黑

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

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

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

伊谢尔伦

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

怪我咯

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

error_log(var_export($data, true));

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

ringa_lee

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

伊谢尔伦

最佳答案:php-console

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

伊谢尔伦

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

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

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

巴扎黑

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

迷茫

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号