Skip to main content
Glama

mcp-debugger

A headless, agentic debugger over MCP β€” let your AI agents debug running programs in seven languages.

CI codecov npm version Docker Pulls License: MIT OpenSSF Scorecard

🎯 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 debug gem / 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 list

Important: 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 --help

Or 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_debug_session

Create a new debugging session

βœ… Implemented

list_debug_sessions

List all active sessions

βœ… Implemented

list_supported_languages

Show available language adapters

βœ… Implemented

set_breakpoint

Set a breakpoint in a file

βœ… Implemented

start_debugging

Start debugging a script

βœ… Implemented

attach_to_process

Attach debugger to a running process

βœ… Implemented

detach_from_process

Detach debugger from a process

βœ… Implemented

get_stack_trace

Get the current stack trace

βœ… Implemented

list_threads

List all threads in the debug session

βœ… Implemented

get_scopes

Get variable scopes for a frame

βœ… Implemented

get_variables

Get variables in a scope

βœ… Implemented

get_local_variables

Get local variables in current frame

βœ… Implemented

step_over

Step over the current line

βœ… Implemented

step_into

Step into a function

βœ… Implemented

step_out

Step out of a function

βœ… Implemented

continue_execution

Continue running

βœ… Implemented

pause_execution

Pause running execution

βœ… Implemented

evaluate_expression

Evaluate expressions in debug context

βœ… Implemented

get_source_context

Get source code context

βœ… Implemented

close_debug_session

Close a session

βœ… Implemented

redefine_classes

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, b

Step 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

🀝 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:force

Debug 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=true to 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:vendor

Running 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-latest

See 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

πŸ™ Acknowledgments

Built with:


Give your AI agents a real debugger β€” in any language.

Install Server
A
license - permissive license
C
quality
A
maintenance

Maintenance

–Maintainers
6dResponse time
4wRelease cycle
10Releases (12mo)
Commit activity
Issues opened vs closed

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

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