Diag WG Update - Many new tools, phasing out some old ones

By Josh Gavant (@joshgav),

In surveys and discussions with Node.js users we consistently hear of your need for better tools and APIs for debugging and understanding your modules and apps. In fact, in last year's Node.js Foundation survey, the biggest ask from developers and technical leads was for better tools.

Based on that feedback and thanks to contributions and collaboration from across our community, over the past year several experimental diagnostic APIs and tools have landed in Node itself and the Node.js Foundation, including:

Over the coming months we'll continue to improve the stability of these projects and hope to eventually graduate some from experimental state with your help and feedback. Search the nodejs GitHub org for labels diag-agenda, tracing, and inspector and review issues in the Diagnostics WG to see what we're working on and how you can help.

Inspector replaces legacy V8 Debugger

With progress comes the need to phase out old implementations so we can focus on refining and completing new ones to meet user needs. In particular, as Inspector graduates from experimental status in the coming months, V8 and Node's legacy Debugger API will be deprecated and eventually removed in favor of the new Inspector API.

Considering the relative imminence of this change, we've decided to add a deprecation warning as soon as possible to prepare users of the legacy interface. So beginning in Node 7.7.0 running node --debug (or variants like --debug-brk and --debug-port=12345) will print a deprecation warning to stderr. To avoid this message, start node with the --no-deprecation flag.

For your future debugging needs, use node --inspect or variants like --inspect-brk to activate the new Inspector API. Many popular editors and tools already automatically support this API with Node.js 6 and later.

In addition, Node's built-in CLI debugger, typically invoked with node debug myscript.js, has now (7.6.0+) been augmented with an Inspector-based equivalent invoked with node inspect myscript.js. node debug myscript.js will eventually be removed as well in favor of node inspect.

Try it!

Check out the Debugging - Getting Started guide for help getting started with --inspect and Inspector.

As always, but particularly in this transition stage, we'd love your feedback both on the insights you need from the Node.js runtime and modules, as well as your experiences getting that info with tools and APIs old and new. Open an issue in the Diagnostics WG for discussions or a PR in nodejs/node to contribute code.

Thank you!

Вгору