
kuzudb-mcp-server
A Model Context Protocol server that provides access to Kuzu databases. This server enables LLMs to inspect database schemas and execute queries on provided kuzu database.
README
kuzudb-mcp-server
A Model Context Protocol server that provides access to Kuzu databases. This server enables LLMs to inspect database schemas and execute queries on provided kuzu database.
Components
Tools
-
getSchema
- Fetch the full schema of the Kuzu database, including all nodes and relationships tables and their properties
- Input: None
-
query
- Run a Cypher query on the Kuzu database
- Input:
cypher
(string): The Cypher query to run
Prompt
- generateKuzuCypher
- Generate a Cypher query for Kuzu
- Argument:
question
(string): The question in natural language to generate the Cypher query for
Usage with Claude Desktop
With Docker (Recommended)
- Edit the configuration file
config.json
:- on macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- on Windows:
%APPDATA%\Claude\claude_desktop_config.json
- on macOS:
- Add the following configuration to the
mcpServers
object:
Change the{ "mcpServers": { "kuzu": { "command": "docker", "args": [ "run", "-v", "{Absolute Path to the Kuzu database}:/database", "--rm", "-i", "kuzudb/mcp-server" ] } } }
{Absolute Path to the Kuzu database}
to the actual path - Restart Claude Desktop
With npm/npx
- Install globally:
npm install -g kuzudb-mcp-server
- Or use directly with npx:
npx kuzudb-mcp-server
- Edit the configuration file
config.json
:- on macOS:
~/Library/Application Support/Claude/claude_desktop_config.json
- on Windows:
%APPDATA%\Claude\claude_desktop_config.json
- on macOS:
- Add the following configuration to the
mcpServers
object:
Change the{ "mcpServers": { "kuzu": { "command": "npx", "args": [ "kuzudb-mcp-server", "{Absolute Path to the Kuzu database}" ] } } }
{Absolute Path to the Kuzu database}
to the actual path - Restart Claude Desktop
Using Environment Variables
You can also specify the database path using the KUZU_MCP_DATABASE_PATH
environment variable instead of passing it as an argument:
{
"mcpServers": {
"kuzu": {
"command": "npx",
"args": ["kuzudb-mcp-server"],
"env": {
"KUZU_MCP_DATABASE_PATH": "{Absolute Path to the Kuzu database}"
}
}
}
}
Alternatively, if you have KUZU_MCP_DATABASE_PATH
set in your system environment, the server will automatically use it when no database path argument is provided.
Read-Only Mode
The server can be run in read-only mode by setting the KUZU_READ_ONLY
environment variable to true
. In this mode, running any query that attempts to modify the database will result in an error. This flag can be set in the configuration file as follows:
With npm/npx:
{
"mcpServers": {
"kuzu": {
"command": "npx",
"args": [
"kuzudb-mcp-server",
"{Absolute Path to the Kuzu database}"
],
"env": {
"KUZU_READ_ONLY": "true"
}
}
}
}
With Docker:
{
"mcpServers": {
"kuzu": {
"command": "docker",
"args": [
"run",
"-v",
"{Absolute Path to the Kuzu database}:/database",
"-e",
"KUZU_READ_ONLY=true",
"--rm",
"-i",
"kuzudb/mcp-server"
]
}
}
}
Multi-Agent Coordination (Experimental)
The server supports multi-agent coordination to allow multiple AI agents (e.g., Claude Desktop and Claude Code) to share the same Kuzu database safely. This feature addresses Kuzu's single-writer limitation through transparent file-based locking.
Enabling Multi-Agent Mode
Set the following environment variables in your configuration:
KUZU_MULTI_AGENT=true
- Enable multi-agent coordinationKUZU_AGENT_ID=string
- Unique identifier for the agent (e.g., "claude-desktop", "claude-code")KUZU_LOCK_TIMEOUT=number
- Lock timeout in milliseconds (default: 10000)
Claude Desktop Configuration
{
"mcpServers": {
"kuzu": {
"command": "npx",
"args": ["kuzudb-mcp-server", "/path/to/database"],
"env": {
"KUZU_MULTI_AGENT": "true",
"KUZU_AGENT_ID": "claude-desktop"
}
}
}
}
Claude Code Configuration
{
"mcpServers": {
"kuzu": {
"command": "npx",
"args": ["kuzudb-mcp-server", "/path/to/database"],
"env": {
"KUZU_MULTI_AGENT": "true",
"KUZU_AGENT_ID": "claude-code"
}
}
}
}
How It Works
When multi-agent mode is enabled:
- Read queries execute immediately without coordination
- Write queries (CREATE, MERGE, SET, DELETE, etc.) acquire an exclusive lock
- Locks are automatically released after query completion
- Stale locks from crashed processes are detected and cleaned up
- Lock conflicts result in clear error messages with retry suggestions
Important Notes
- This feature is experimental and designed for local development scenarios
- Both agents must point to the same database path
- The lock file (
.mcp_write_lock
) is created in the database directory - Lock timeout defaults to 10 seconds, which covers most operations
Development
To build from source:
# Clone the repository
git clone https://github.com/jordanburke/kuzudb-mcp-server.git
cd kuzudb-mcp-server
# Install dependencies
pnpm install
# Build the project
pnpm run build
# Run development mode with watch
pnpm run dev
# Run tests and linting
pnpm run lint
pnpm run typecheck
pnpm run format:check
For local development, you can also configure Claude Desktop to use the local build:
{
"mcpServers": {
"kuzu": {
"command": "node",
"args": [
"/path/to/kuzudb-mcp-server/dist/index.js",
"/path/to/kuzu/database"
]
}
}
}
Documentation
Core Features
- Connection Recovery - Automatic connection recovery, retry logic, and error handling
- Multi-Agent Coordination - Safe concurrent access with file-based locking
- Batch Query Improvements - Enhanced DDL and multi-statement query handling
Bug Workarounds
- Kuzu Bug Workarounds - Temporary fixes for known Kuzu issues
Environment Variables
Variable | Description | Default |
---|---|---|
KUZU_READ_ONLY |
Enable read-only mode | false |
KUZU_MAX_RETRIES |
Connection recovery retry attempts | 2 |
KUZU_MULTI_AGENT |
Enable multi-agent coordination | false |
KUZU_AGENT_ID |
Unique agent identifier | unknown-{pid} |
KUZU_LOCK_TIMEOUT |
Lock acquisition timeout (ms) | 10000 |
KUZU_MCP_DATABASE_PATH |
Database path if not provided as argument | - |
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.
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.
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.

VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.

E2B
Using MCP to run code via e2b.
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.