MCP Debugger
The MCP Debugger is a multi-language debugging server that enables AI agents to perform step-through debugging through the Debug Adapter Protocol (DAP). It provides structured API calls with JSON responses for debugging Python, JavaScript/Node.js, Rust, and Go, with a mock adapter for testing.
Core Capabilities:
Session Management: Create, list, and close independent debugging sessions for different languages and projects
Breakpoint Control: Set breakpoints at specific file paths and line numbers with support for conditional breakpoints and AI-aware intelligent placement
Execution Control: Start debugging scripts with custom arguments and adapter-specific launch configurations, then step over/into/out, continue execution, or pause (pause currently not implemented)
State Inspection: Retrieve stack traces with optional filtering of internal frames, examine variable scopes (Locals, Globals, etc.) for any frame, and access variables using variablesReference numbers or quickly get local variables for the current frame
Expression Evaluation: Evaluate arbitrary expressions in the debug context to read or modify program state (currently defined but not implemented)
Source Context: Retrieve code snippets around specific lines for better debugging visibility
Language Discovery: List all supported debugging languages with their metadata
Key Features:
Auto-detection of language executables (debugpy for Python, js-debug for Node.js, CodeLLDB for Rust) with optional manual path specification
Handles both absolute and relative file paths with validation to prevent crashes
Optional filtering of special variables and internal stack frames for cleaner output
Clean adapter architecture supporting dynamic loading and future language support (Ruby, C/C++)
Flexible deployment via npm, npx (zero-runtime dependencies), or Docker with STDIO and SSE transport modes
Enables step-through debugging for JavaScript applications with tools for managing breakpoints, stack traces, and variable scopes.
Supports debugging of Node.js applications, providing tools to control execution and inspect program state through the Debug Adapter Protocol.
Provides debugging capabilities for Python code, including setting breakpoints, inspecting variables, and stepping through execution using debugpy.
Supports debugging Rust programs and Cargo projects, enabling variable inspection and source context tracking via CodeLLDB.
Provides debugging support for TypeScript projects, allowing for interactive code execution and inspection within the MCP environment.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MCP Debuggerdebug this Python script and show me the variables at line 15"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-debugger
A headless, agentic debugger over MCP β let your AI agents debug running programs in seven languages.
π― Overview
mcp-debugger is a Model Context Protocol (MCP) server that exposes step-through debugging as structured tool calls. It lets AI agents set breakpoints, inspect variables, evaluate expressions, and step through running programs across seven languages β driving real language debuggers through the Debug Adapter Protocol (DAP).
π v0.21.0 β the minimum runtime is now Node.js 22+ (Node 20 reached end-of-life). See the CHANGELOG for the full release history.
Related MCP server: cdp-tools-mcp
β¨ Key Features
π Multi-language support β Clean adapter pattern for any language
π Python debugging via debugpy β Full DAP protocol support
π Ruby debugging via rdbg β Launch and attach workflows, including remote attach to containers and Kubernetes pods
π¨ JavaScript (Node.js) debugging via js-debug β VSCode's proven debugger
π¦ Rust debugging via CodeLLDB β Debug Rust & Cargo projects (Linux/macOS; Windows needs the GNU toolchain β see Rust on Windows)
πΉ Go debugging via Delve β Full DAP support for Go programs
β Java debugging via JDI bridge β Launch and attach modes with JDK 21+
π· .NET/C# debugging via netcoredbg β Debug .NET applications with full DAP support
π§ͺ Mock adapter for testing β Test without external dependencies
π°οΈ Out-of-IDE & remote attach β Attach over host/port to a process on another machine or inside a container (Python via debugpy, Ruby via rdbg, Java via JDWP), with source-path mapping
π STDIO and Streamable HTTP transports β Works with any MCP client (legacy SSE transport is deprecated)
π¦ Zero-runtime dependencies β Self-contained bundles via esbuild + tsup
β‘ npx ready β Run directly with
npx @debugmcp/mcp-debugger- no installation neededπ³ Docker and npm packages β Deploy anywhere
π€ Built for AI agents β Structured JSON responses for easy parsing
π‘οΈ Path validation β Prevents crashes from non-existent files
π AI-aware line context β Intelligent breakpoint placement with code context
β Comprehensive test suite β unit, integration, and end-to-end coverage across every adapter (CI status)
π Quick Start
Requirements: Node.js 22+ for the server. Each language you debug also needs its own toolchain installed (Python + debugpy, Ruby + the
debuggem /rdbg, Node.js, Go + Delve, JDK 21+, .NET SDK, or the Rust toolchain).
For MCP Clients (Claude Desktop, etc.)
Add to your MCP settings configuration:
{
"mcpServers": {
"mcp-debugger": {
"command": "node",
"args": ["C:/path/to/mcp-debugger/dist/index.js", "stdio", "--log-level", "debug", "--log-file", "C:/path/to/logs/debug-mcp-server.log"],
"disabled": false,
"autoApprove": ["create_debug_session", "set_breakpoint", "get_variables"]
}
}
}For Claude Code CLI
For Claude Code users, we provide an automated installation script:
Prerequisite: The Claude CLI must be installed and available on your PATH before running the installation script. See Claude Code documentation for installation instructions.
# Clone the repository
git clone https://github.com/debugmcp/mcp-debugger.git
cd mcp-debugger
# Run the installation script
./scripts/install-claude-mcp.sh
# Verify the connection (use 'claude mcp list' if claude is on your PATH)
claude mcp listImportant: The stdio argument is required to prevent console output from corrupting the JSON-RPC protocol. See CLAUDE.md for detailed setup and troubleshooting.
Using Docker
docker run -v $(pwd):/workspace debugmcp/mcp-debugger:latestβ οΈ The Docker image ships Python, JavaScript, Go, Java, and .NET adapters. Rust debugging requires the local, SSE, or packed deployments where the adapter runs next to your toolchain. Note: adapters are loaded dynamically at runtime β only those whose toolchain is installed and detected will be reported as available by
list_supported_languages.
Using npm
npm install -g @debugmcp/mcp-debugger
mcp-debugger --helpOr use without installation via npx:
npx @debugmcp/mcp-debugger --helpπ How It Works
mcp-debugger exposes debugging operations as MCP tools that can be called with structured JSON parameters:
// Tool: create_debug_session
// Request:
{
"language": "python", // or "ruby", "javascript", "rust", "go", "java", "dotnet", or "mock" for testing
"name": "My Debug Session"
}
// Response:
{
"success": true,
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"message": "Created python debug session: My Debug Session"
}π οΈ Available Tools
Tool | Description | Status |
| Create a new debugging session | β Implemented |
| List all active sessions | β Implemented |
| Show available language adapters | β Implemented |
| Set a breakpoint in a file | β Implemented |
| Start debugging a script | β Implemented |
| Attach debugger to a running process | β Implemented |
| Detach debugger from a process | β Implemented |
| Get the current stack trace | β Implemented |
| List all threads in the debug session | β Implemented |
| Get variable scopes for a frame | β Implemented |
| Get variables in a scope | β Implemented |
| Get local variables in current frame | β Implemented |
| Step over the current line | β Implemented |
| Step into a function | β Implemented |
| Step out of a function | β Implemented |
| Continue running | β Implemented |
| Pause running execution | β Implemented |
| Evaluate expressions in debug context | β Implemented |
| Get source code context | β Implemented |
| Close a session | β Implemented |
| Hot-swap changed Java classes into a running JVM (Java only) | β Implemented |
ποΈ Architecture: Dynamic Adapter Loading
Version 0.10.0 introduces a clean adapter pattern that separates language-agnostic core functionality from language-specific implementations:
βββββββββββββββ ββββββββββββββββββ ββββββββββββββββ βββββββββββββββββββ
β MCP Client ββββββΆβ DebugMcpServer ββββββΆβSessionManagerββββββΆβ AdapterRegistry β
βββββββββββββββ ββββββββββββββββββ ββββββββββββββββ βββββββββββββββββββ
β β
βΌ βΌ
ββββββββββββββββ βββββββββββββββββββ
β ProxyManager ββββββββ Language Adapterβ
ββββββββββββββββ βββββββββββββββββββ
β
ββββββββββββββββ΄βββββββββββββββββββββββββββββββββββββββββββ
β β
βββββββββββββΌββββββββββββ¬ββββββββββββ¬ββββββββββββ¬ββββββββββββ β
β β β β β β β
βββββββΌββββββββββββΌββββββββββββΌββββββββββββΌββββββββββββΌββββββββββββΌβββββ
βPython ββJavaScriptββRust ββGo ββJava ββDotnet ββMock β
βAdapter ββAdapter ββAdapter ββAdapter ββAdapter ββAdapter ββAdapter β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββοΏ½οΏ½οΏ½ββββAdding Language Support
Want to add debugging support for your favorite language? Check out the Adapter Development Guide!
π‘ Example: Debugging Python Code
Here's a complete debugging session example:
# buggy_swap.py
def swap_variables(a, b):
a = b # Bug: loses original value of 'a'
b = a # Bug: 'b' gets the new value of 'a'
return a, bStep 1: Create a Debug Session
// Tool: create_debug_session
// Request:
{
"language": "python",
"name": "Swap Bug Investigation"
}
// Response:
{
"success": true,
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"message": "Created python debug session: Swap Bug Investigation"
}Step 2: Set Breakpoints
// Tool: set_breakpoint
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"file": "buggy_swap.py",
"line": 2
}
// Response:
{
"success": true,
"breakpointId": "28e06119-619e-43c0-b029-339cec2615df",
"file": "C:\\path\\to\\buggy_swap.py",
"line": 2,
"verified": false,
"message": "Breakpoint set at C:\\path\\to\\buggy_swap.py:2"
}Step 3: Start Debugging
// Tool: start_debugging
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"scriptPath": "buggy_swap.py"
}
// Response:
{
"success": true,
"state": "paused",
"message": "Debugging started for buggy_swap.py. Current state: paused",
"data": {
"message": "Debugging started for buggy_swap.py. Current state: paused",
"reason": "breakpoint"
}
}Step 4: Inspect Variables
First, get the scopes:
// Tool: get_scopes
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"frameId": 3
}
// Response:
{
"success": true,
"scopes": [
{
"name": "Locals",
"variablesReference": 5,
"expensive": false,
"presentationHint": "locals",
"source": {}
},
{
"name": "Globals",
"variablesReference": 6,
"expensive": false,
"source": {}
}
]
}Then get the local variables:
// Tool: get_variables
// Request:
{
"sessionId": "a4d1acc8-84a8-44fe-a13e-28628c5b33c7",
"scope": 5
}
// Response:
{
"success": true,
"variables": [
{"name": "a", "value": "10", "type": "int", "variablesReference": 0, "expandable": false},
{"name": "b", "value": "20", "type": "int", "variablesReference": 0, "expandable": false}
],
"count": 2,
"variablesReference": 5
}π Documentation
π Tool Reference β Complete API documentation
π¦ Getting Started Guide β First-time setup
ποΈ Architecture Overview β Multi-language design
π§ Adapter Development β Add new languages
π Dynamic Loading Architecture β Runtime discovery, lazy loading, caching
π§© Adapter API Reference β Adapter, factory, loader, and registry contracts
π Migration Guide β Upgrading to v0.15.0 (dynamic loading)
π Python Debugging Guide β Python-specific features
π Ruby Debugging Guide β Ruby debugging with
rdbg, including remote attachπ¨ JavaScript Debugging Guide β JavaScript/TypeScript features
πΉ Go Debugging Guide β Go debugging with Delve
β Java Debugging Guide β Java debugging with JDI bridge
Rust Debugging on Windows - Toolchain requirements and troubleshooting
π§ Troubleshooting β Common issues & solutions
π€ Contributing
We welcome contributions! See CONTRIBUTING.md for guidelines.
# Development setup
git clone https://github.com/debugmcp/mcp-debugger.git
cd mcp-debugger
# Install dependencies and vendor debug adapters
pnpm install
# All debug adapters (JavaScript js-debug, Rust CodeLLDB) are automatically downloaded
# Build the project
pnpm build
# Run tests
pnpm test
# Check adapter vendoring status
pnpm vendor:status
# Force re-vendor all adapters (if needed)
pnpm vendor:forceDebug Adapter Vendoring
The project automatically vendors debug adapters during pnpm install:
JavaScript: Downloads Microsoft's js-debug from GitHub releases
Rust: Downloads CodeLLDB binaries for the current platform
CI Environment: Set
SKIP_ADAPTER_VENDOR=trueto skip vendoring
To manually manage adapters:
# Check current vendoring status
pnpm vendor:status
# Re-vendor all adapters
pnpm vendor
# Clean and re-vendor (force)
pnpm vendor:force
# Clean vendor directories only
pnpm clean:vendorRunning Container Tests Locally
We use Act to run GitHub Actions workflows locally:
# Build the Docker image first
docker build -t mcp-debugger:local .
# Run tests with Act (use WSL2 on Windows)
act -j build-and-test --matrix os:ubuntu-latestSee tests/README.md for detailed testing instructions.
π Project Status
β Production Ready: v0.21.0 with seven language adapters and polished multi-language distribution
β Clean architecture with a dynamic adapter pattern
β Python Β· Ruby Β· JavaScript/TypeScript Β· Go Β· Java Β· .NET/C#: Full step-through debugging
π¦ Rust: Full support on Linux/macOS/Windows (Windows requires the GNU toolchain; MSVC is not supported by CodeLLDB)
π’ Runtime: Node.js 22+
π Active Development: Regular updates and improvements
π License
MIT License - see LICENSE for details.
π₯ Contributors
@Poyraxx β Ruby adapter (rdbg)
@swinyx β Go adapter (Delve)
@roofpig95008 β Java adapter (JDI bridge)
π Acknowledgments
Built with:
Model Context Protocol by Anthropic
Debug Adapter Protocol by Microsoft
debugpy for Python debugging
debug for Ruby debugging
Give your AI agents a real debugger β in any language.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/debugmcp/mcp-debugger'
If you have feedback or need assistance with the MCP directory API, please join our Discord server