Go Delve Debugger MCP Server
by xhd2015
An MCP server that allows LLMs to interact with the Delve Go debugger. It enables AI assistants to debug Go applications by exposing tools to start, control, and interact with debug sessions.
Last updated: N/A
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