mcp-debugger-node
MCP server for debugging Node.js programs through the V8 Inspector Protocol, allowing AI agents to set breakpoints, inspect variables, and step through code.
README
mcp-debugger-node
MCP server for debugging Node.js programs through the V8 Inspector Protocol.
This server gives an AI agent debugger-style tools: start a Node process under
--inspect-brk, set breakpoints, continue execution, wait for pauses, step,
inspect variables, and evaluate expressions in the current call frame.
[!WARNING] This server starts whatever command is provided in the
resettarget config. Only use it in trusted local development environments. A target config can run arbitrary commands with your user permissions.
Run
This package is meant to be started by an MCP client over stdio:
npx -y mcp-debugger-node
You usually do not run that command by hand. Instead, add it to your agent or editor MCP configuration.
Codex
Add this to ~/.codex/config.toml:
[mcp_servers.node-debugger]
command = "npx"
args = ["-y", "mcp-debugger-node"]
Claude Code
Use the Claude Code MCP CLI:
claude mcp add node-debugger -- npx -y mcp-debugger-node
For a project-local config, run that command from the project you want to configure.
GitHub Copilot in VS Code
Create or update .vscode/mcp.json:
{
"servers": {
"node-debugger": {
"type": "stdio",
"command": "npx",
"args": ["-y", "mcp-debugger-node"]
}
}
}
Other MCP Clients
Use a stdio server entry with:
{
"command": "npx",
"args": ["-y", "mcp-debugger-node"]
}
Quick Start
Start a debug session by calling reset with an explicit target:
{
"target": {
"cwd": "/path/to/project",
"command": "node",
"args": ["--inspect-brk=0", "server.js"]
}
}
For a CommonJS TypeScript project using ts-node:
{
"target": {
"cwd": "/path/to/project",
"command": "node",
"args": ["--inspect-brk=0", "-r", "ts-node/register", "src/index.ts"]
}
}
For an ESM TypeScript project:
{
"target": {
"cwd": "/path/to/project",
"command": "node",
"args": ["--inspect-brk=0", "--loader", "ts-node/esm", "src/index.ts"]
}
}
The target must include --inspect-brk=0. The server reads the inspector URL
from the target process stderr and connects to it.
Common Workflow
For simple scripts:
- Call
resetwith a target. - Call
set_breakpoint. - Call
resume. - Call
getvariablesorevaluate. - Use
stepoverorstepintoas needed.
For event-driven servers:
- Call
resetwith a target. - Call
set_breakpointin the endpoint or handler. - Call
continue. - Trigger the event with curl, a browser, a test runner, or another tool.
- Call
wait_for_pause. - Inspect runtime state with
getvariablesandevaluate. - Call
continueagain to let the request finish.
Example endpoint debugging flow:
{
"urlRegex": "server\\.js$",
"lineNumber": 42
}
Then:
continue
curl http://localhost:3000/api/users
wait_for_pause
evaluate {"expression":"req.url"}
getvariables
continue
Tools
reset
Restart the debug session with a fresh Node inspector process.
Input:
{
"target": {
"cwd": "/path/to/project",
"command": "node",
"args": ["--inspect-brk=0", "server.js"],
"env": {
"NODE_ENV": "development"
}
}
}
env is optional and is merged with the MCP server environment.
set_breakpoint
Set a breakpoint by matching a script URL with a regex.
Input:
{
"urlRegex": "server\\.js$",
"lineNumber": 10
}
lineNumber is zero-based, matching the Chrome DevTools Protocol.
set_pause_on_exceptions
Configure exception pause behavior.
Input:
{
"state": "uncaught"
}
Allowed states:
noneuncaughtall
The default is uncaught.
continue
Resume execution and return immediately.
Use this when some external action needs to trigger the breakpoint, such as a curl request or browser interaction.
wait_for_pause
Wait until the debugged process pauses and return the current location.
Useful after continue when another tool is triggering the application.
resume
Resume execution and wait for the next pause.
This is convenient for scripts where the next pause will happen without an external trigger.
stepover
Step over the current statement and wait for the next pause.
stepinto
Step into the next function call and wait for the next pause.
getvariables
Get variables for the latest paused call frame scope.
evaluate
Evaluate JavaScript in the latest paused call frame.
Input:
{
"expression": "JSON.stringify(req.body)"
}
Exception Reporting
The debugger pauses on uncaught exceptions by default. When an exception pause happens, the pause result includes exception metadata:
{
"reason": "exception",
"lineNumber": 8,
"columnNumber": 3,
"exception": {
"className": "Error",
"description": "Error: file is not a database ..."
}
}
This lets agents diagnose startup crashes and runtime failures without reading server logs.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.