如何调试Node.js服务器应用程序?

现在,我主要使用如下打印语句的警报调试:

sys.puts(sys.inspect(someVariable));

必须有更好的调试方法。我知道Google Chrome有一个命令行调试器。这个调试器也适用于Node.js吗?


当前回答

如果您需要Node.js的强大日志库,Tracerhttps://github.com/baryon/tracer是更好的选择。

它输出带有时间戳、文件名、方法名、行号、路径或调用堆栈的日志消息,支持颜色控制台,并轻松支持数据库、文件和流传输。我是作者。

其他回答

我为那些不知道从哪里开始使用节点检查器的人编写了一个简短的Node.js调试入门。

这里有很多很好的答案,但我想补充一下我的观点(基于我的方法的演变)

除错记录

让我们面对现实吧,我们都喜欢一个好的console.log(“哦,如果你到了这里,你最好跑一下。”),有时候这很有用,所以如果你不想离开它太远,至少可以通过Visionmedia的调试为你的日志添加一些亮点。

交互式调试

尽管控制台日志记录非常方便,但要进行专业调试,您需要卷起袖子并陷入其中。设置断点,单步执行代码,检查范围和变量,以了解导致这种奇怪行为的原因。正如其他人所提到的,节点检查器实际上是蜜蜂的膝盖。它完成了内置调试器所能做的一切,但使用了熟悉的ChromeDevTools界面。如果像我一样使用Webstorm,那么这里有一个方便的调试指南。

堆栈跟踪

默认情况下,我们无法在事件循环的不同周期(滴答声)中跟踪一系列操作。要解决这个问题,请查看longjohn(但不在生产中!)。

内存渗漏体

使用Node.js,我们可以让服务器进程保持相当长的时间。如果你认为它引发了一些严重的泄漏,你该怎么办?使用heapdump和ChromeDevTools比较一些快照,看看有什么变化。


有关一些有用的文章,请查看

RisingStack-调试Node.js应用程序nearForm的David Mark Clements的优秀文章

如果你想看视频,那么

Netflix JS Talks-调试生产中的Node.JS跟踪工作组关于跟踪和调试node.js的有趣视频关于节点检查器的15分钟视频

无论您选择什么路径,只要确保您了解如何调试

这是一件痛苦的事看看你自己的麻烦你自己和其他人都没有成功索福克勒斯,阿贾克斯

请尝试有趣的方法来调试Node.js应用程序(不仅仅是)使用智能日志

https://github.com/darky/the-most-convenient-debug

调试

Joyent指南调试器节点检查器Visual Studio代码云9括号

分析

节点--教授/应用程序.jsnode—prof进程/生成的日志文件

堆转储

使用Chrome开发者工具的节点堆转储

火焰图

0倍jam3/devtool然后是Chrome开发者工具火焰图Dtrace和StackVis-仅在SmartOS上受支持临床医师

跟踪

使用TraceGL的交互式堆栈跟踪

登录中

输出调试信息的库

毛虫示踪剂潦草

增强堆栈跟踪信息的库

朗约翰

标杆管理

Apache工作台:ab-n 100000-c 1http://127.0.0.1:9778/wrk公司

另外

查出优势家伙Google跟踪框架保罗·爱尔兰指南

遗产

这些功能可以使用,但不再维护或不再适用于现代节点版本。

https://github.com/bnoordhuis/node-profiler-替换为内置调试https://github.com/c4milo/node-webkit-agent-由节点检查器替换https://nodetime.com/-失效

调试Node.JS应用程序的方法如下:

1) 安装devtool并用它启动应用程序

npm install devtool -g --save
devtool server.js

这将在chrome开发人员模式下打开,因此您可以放置调试器点并进行测试。

2) 使用节点检查器进行调试

node-inspector

3) 使用--debug调试

node --debug app.js