MCP Debug Recorder
Record debug sessions, commands, failed attempts, and successful fixes in local SQLite storage.
README
mcp-debug-recorder
mcp-debug-recorder answers a simple question fast: have I fixed this before?
It records debug sessions, terminal commands, failed attempts, and successful fixes in a local SQLite database so your MCP client can query your own debugging history in natural language.
Quick Start
npx mcp-debug-recorder
By default, data is stored at ~/.mcp-debug-recorder/sessions.db.
Architecture
src/
├── db.ts - openDb(), createTestDb(), versioned MIGRATIONS[]
├── store.ts - Store class with dependency-injected SQLite access
├── search.ts - FTS5 + Fuse.js hybrid search
├── tools/ - MCP tool handlers grouped by session/search/admin concerns
├── types.ts - Zod schemas and TypeScript types
├── mcp.ts - MCP server wiring + tool registration
├── server-http.ts - Streamable HTTP transport
├── logging.ts - Structured logging with secret redaction
└── version.ts - Package version helper
Schema versioning
The database schema is versioned via PRAGMA user_version. Migrations run automatically on startup, so upgrading does not require manual SQL.
Adding a custom database path
DEBUG_RECORDER_DB=/path/to/custom.db npx mcp-debug-recorder
Configuration
Environment variables
DEBUG_RECORDER_DB: override the SQLite database pathPORT: override the HTTP server port for Streamable HTTP modeLOG_LEVEL: minimum structured log level (debug,info,warn,error)FUZZY_THRESHOLD: override the Fuse.js threshold used during reranking
Available Tools
start_debug_session: start tracking a new issueadd_fix: record a failed or successful fix attemptrecord_command: save a terminal command and its outputclose_session: mark a session as resolved or abandonedupdate_session: edit title, description, or tagsdelete_session: permanently delete a session with explicit confirmationsearch_sessions: search historical sessions with FTS5 + fuzzy rerankingfind_similar_errors: ask whether you have seen a similar error beforeget_session: fetch full session detailsget_session_context: fetch an AI-friendly summary of a sessionlist_sessions: browse sessions with filtersget_stats: summarize your debug historyexport_sessions: export your local history for backup or migrationimport_sessions: import a previously exported JSON payload
Client Setup
Claude Desktop
{
"mcpServers": {
"mcp-debug-recorder": {
"command": "npx",
"args": ["mcp-debug-recorder"]
}
}
}
VS Code / GitHub Copilot
Create or update .vscode/mcp.json:
{
"servers": {
"mcp-debug-recorder": {
"type": "stdio",
"command": "npx",
"args": ["mcp-debug-recorder"]
}
}
}
Codex CLI
codex mcp add mcp-debug-recorder -- npx mcp-debug-recorder
codex mcp list
Gemini CLI
gemini mcp add mcp-debug-recorder npx mcp-debug-recorder
gemini mcp list
Antigravity
antigravity --add-mcp "{\"name\":\"mcp-debug-recorder\",\"command\":\"npx\",\"args\":[\"mcp-debug-recorder\"]}"
Real Usage Examples
Have I seen this before?
"I'm getting
TypeError: Cannot read properties of undefined, have I seen this before?"
Call find_similar_errors with the current error text, then inspect the best match with get_session_context.
Record an active incident
- Call
start_debug_session - Add terminal commands with
record_command - Add each attempted fix with
add_fix - Use
update_sessionwhen the title or notes become clearer - Close the session with
close_session
Back up your local debug history
- Call
export_sessionswithformat: "json" - Save the returned JSON in your preferred backup system
- Restore later with
import_sessions
Data Storage
- Default path:
~/.mcp-debug-recorder/sessions.db - Portable SQLite storage with
better-sqlite3 - FTS5-backed search index for large histories
- No external database server required
Note:
better-sqlite3uses a native addon. If you see binding errors, runnpm rebuild better-sqlite3for your Node version.
HTTP Transport
The package also supports Streamable HTTP:
npm run start:http
Useful routes:
GET /healthGET /version- MCP endpoint:
POST/GET/DELETE /mcp
Development
npm ci
npm run lint
npm test
npm run build
npm run test:e2e
npm run docs:api
For release verification:
npm run format:check
npm run test:coverage
npm run prepublishOnly
Additional project docs:
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
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.
E2B
Using MCP to run code via e2b.