Node.js Debugger
STDIOMCP server providing comprehensive Node.js debugging capabilities using Chrome DevTools Protocol with breakpoints and inspection.
MCP server providing comprehensive Node.js debugging capabilities using Chrome DevTools Protocol with breakpoints and inspection.
An MCP server that provides comprehensive Node.js debugging capabilities using the Chrome DevTools Protocol. This server enables AI assistants to debug Node.js applications with full access to breakpoints, stepping, variable inspection, call stacks, expression evaluation, and source maps.
This MCP server is useful when you need AI assistance with debugging Node.js applications. It provides programmatic access to all the debugging features you'd find in Chrome DevTools or VS Code, allowing AI assistants to help you set breakpoints, inspect variables, step through code, and analyze runtime behavior.
this preview, and drill down into object propertiesnpm install devtools-debugger-mcp
Add the server to your MCP settings configuration:
{ "devtools-debugger-mcp": { "command": "node", "args": ["path/to/devtools-debugger-mcp/dist/index.js"] } }
Alternatively, if installed globally, you can use the CLI binary:
{ "devtools-debugger-mcp": { "command": "devtools-debugger-mcp" } }
This MCP server can debug Node.js programs by launching your script with the built‑in inspector (--inspect-brk=0) and speaking the Chrome DevTools Protocol (CDP).
How it works
start_node_debug spawns node --inspect-brk=0 your-script.js, waits for the inspector WebSocket, attaches, and returns the initial pause (first line) with a pauseId and top call frame.Quickstart (from an MCP-enabled client)
{ "tool": "start_node_debug", "params": { "scriptPath": "/absolute/path/to/app.js" } }
{ "tool": "set_breakpoint", "params": { "filePath": "/absolute/path/to/app.js", "line": 42 } }
{ "tool": "resume_execution", "params": { "includeConsole": true, "includeStack": true } }
{ "tool": "inspect_scopes", "params": { "maxProps": 15 } } { "tool": "evaluate_expression", "params": { "expr": "user.name" } }
{ "tool": "step_over" } { "tool": "step_into" } { "tool": "step_out" }
{ "tool": "stop_debug_session" }
Node.js tool reference (summary)
start_node_debug({ scriptPath, format? }) — Launches Node with inspector and returns initial pause.set_breakpoint({ filePath, line }) — Breakpoint by file path (1-based line).set_breakpoint_condition({ filePath?, urlRegex?, line, column?, condition, format? }) — Conditional breakpoint or by URL regex.add_logpoint({ filePath?, urlRegex?, line, column?, message, format? }) — Logpoint via conditional breakpoint that logs and returns false.set_exception_breakpoints({ state }) — none | uncaught | all.blackbox_scripts({ patterns }) — Ignore frames from matching script URLs.list_scripts() / get_script_source({ scriptId? | url? }) — Discover and fetch script sources.continue_to_location({ filePath, line, column? }) — Run until a specific source location.restart_frame({ frameIndex, pauseId?, format? }) — Re-run the selected frame.resume_execution({ includeScopes?, includeStack?, includeConsole?, format? }) — Continue to next pause or exit.step_over|step_into|step_out({ includeScopes?, includeStack?, includeConsole?, format? }) — Stepping with optional context in the result.evaluate_expression({ expr, pauseId?, frameIndex?, returnByValue?, format? }) — Evaluate in a paused frame; defaults to top frame.inspect_scopes({ maxProps?, pauseId?, frameIndex?, includeThisPreview?, format? }) — Locals/closures and this summary.get_object_properties({ objectId, maxProps?, format? }) — Drill into object previews.list_call_stack({ depth?, pauseId?, includeThis?, format? }) — Top N frames summary.get_pause_info({ pauseId?, format? }) — Pause reason/location summary.read_console({ format? }) — Console messages since the last step/resume.stop_debug_session() — Kill process and detach.Notes
file:// URLs internally for CDP compatibility.line is 1-based; CDP is 0-based internally.includeConsole on step/resume or with read_console.set_output_format({ format: 'text' | 'json' | 'both' }) to set default response formatting.This MCP server provides the following Node.js debugging tools. All tools support optional format parameter ('text' or 'json') to control response formatting.
start_node_debug - Launch a Node.js script with debugging enabledstop_debug_session - Terminate the debugging session and clean upset_breakpoint - Set a breakpoint at a specific file and lineset_breakpoint_condition - Set a conditional breakpoint or breakpoint by URL regexadd_logpoint - Add a logpoint that logs messages when hitset_exception_breakpoints - Configure pause-on-exception behaviorresume_execution - Continue execution to the next breakpoint or completionstep_over - Step over the current linestep_into - Step into function callsstep_out - Step out of the current functioncontinue_to_location - Run until reaching a specific locationrestart_frame - Restart execution from a specific call frameinspect_scopes - Examine local variables, closures, and this contextevaluate_expression - Evaluate JavaScript expressions in the current contextget_object_properties - Drill down into object propertieslist_call_stack - View the current call stackget_pause_info - Get information about the current pause statelist_scripts - List all loaded scriptsget_script_source - Retrieve source code for scriptsblackbox_scripts - Configure scripts to skip during debuggingread_console - Read console output captured during debuggingFor detailed usage examples and parameter descriptions, see the "Node.js Debugging" section above.
MIT