Go Delve Debugger MCP Server
An MCP server that allows LLMs to interact with the Delve Go debugger.
Description
This project implements a Model Context Protocol (MCP) server that integrates with the Delve Go debugger to enable AI assistants to debug Go applications. The server exposes a set of tools that allow LLMs to start, control, and interact with debug sessions.
You can find a working example at EXAMPLE.md.
Features
- Start debug sessions for Go programs
- Set breakpoints in code
- Step through code (next, step in, step out)
- Evaluate expressions in the context of a debug session
- Inspect variables and stack traces
- Manage multiple debug sessions
Installation
Prerequisites
- Go 1.21 or higher
- Delve debugger installed (
go install github.com/go-delve/delve/cmd/dlv@latest)
Install
go install github.com/xhd2015/dlv-mcp/cmd/dlv-mcp@latest
Usage
Start the MCP server:
dlv-mcp --listen :9097
Then configure MCP Server at http://localhost:9097/sse, in Cursor or any MCP client.
Inspect the MCP Server
bunx @modelcontextprotocol/inspector dlv-mcp
Available Tools
Debug Session Management
-
start_debug: Start a new debug sessionprogram: Path to Go program to debugargs: Command line arguments for the program (optional)mode: Debug mode (debug,test, orexec, default:debug)
-
terminate_debug: Terminate a debug sessionsession_id: ID of the debug session to terminate
-
list_debug_sessions: List active debug sessions
Breakpoint Management
set_breakpoint: Set a breakpoint in a debug sessionsession_id: ID of the debug sessionfile: Source file to set breakpoint in (absolute path)line: Line number to set breakpoint at
Execution Control
-
continue: Continue execution in a debug sessionsession_id: ID of the debug session
-
next: Step over current line in a debug sessionsession_id: ID of the debug session
-
step_in: Step into function in a debug sessionsession_id: ID of the debug session
-
step_out: Step out of function in a debug sessionsession_id: ID of the debug session
Inspection
evaluate: Evaluate an expression in a debug sessionsession_id: ID of the debug sessionexpression: Expression to evaluateframe_id: Stack frame ID (optional, default: 0)
Example Workflow
-
Start a debug session:
start_debug program=/path/to/program.go -
Set a breakpoint:
set_breakpoint session_id=session-123456 file=/path/to/program.go line=15 -
Continue to breakpoint:
continue session_id=session-123456 -
Evaluate an expression:
evaluate session_id=session-123456 expression="myVariable" -
Step over a line:
next session_id=session-123456 -
Terminate the session:
terminate_debug session_id=session-123456
Architecture
The server is built using the following components:
- MCP Server Layer: Implements the Model Context Protocol using mark3labs/mcp-go
- DAP Client Layer: Communicates with Delve's DAP server
- Session Management: Maintains and manages debug sessions
Inspect The MCP Server
bunx @modelcontextprotocol/inspector go run ./cmd/dlv-mcp
Using the Demo Client
We've created a demo client that shows how to use the debugger-mcp server programmatically. The demo:
- Starts the MCP server
- Launches a debug session for
./testdata/hello.go - Tries to set a breakpoint and execute debugging commands
- Properly terminates the session and server
To run the demo:
go run ./demo/main.go
The demo client showcases how to:
- Start and communicate with the MCP server using JSON-RPC
- Send tool calls using the correct format
- Parse and handle responses
- Deal with errors gracefully
Check out demo/main.go and demo/README.md for more details on the implementation.
License
MIT License