π Connect AI models to FalkorDB graph databases through the Model Context Protocol
FalkorDB MCP Server enables AI assistants like Claude to interact with FalkorDB graph databases using natural language. Query your graph data, create relationships, and manage your knowledge graph - all through conversational AI.
This server implements the Model Context Protocol (MCP), allowing AI models to:
- Query graph databases using OpenCypher
- Create and manage nodes and relationships
- Store and retrieve key-value data
- List and explore multiple graphs
- Delete graphs when needed
- Node.js 16+
- FalkorDB instance (running locally or remotely)
- Claude Desktop app (for AI integration)
Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json
on macOS):
{
"mcpServers": {
"falkordb": {
"command": "npx",
"args": [
"-y",
"falkordb-mcpserver@latest"
],
"env": {
"FALKORDB_HOST": "localhost",
"FALKORDB_PORT": "6379",
"FALKORDB_USERNAME": "",
"FALKORDB_PASSWORD": ""
}
}
}
}
-
Clone and install:
git clone https://github.com/SecKatie/falkordb-mcpserver.git cd falkordb-mcpserver npm install
-
Configure environment:
cp .env.example .env
Edit
.env
:# Environment Configuration NODE_ENV=development # FalkorDB Configuration FALKORDB_HOST=localhost FALKORDB_PORT=6379 FALKORDB_USERNAME= # Optional FALKORDB_PASSWORD= # Optional # Redis Configuration (for key-value operations) REDIS_URL=redis://localhost:6379 REDIS_USERNAME= # Optional REDIS_PASSWORD= # Optional # Logging Configuration (optional) ENABLE_FILE_LOGGING=false
-
Build the project:
npm run build
Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json
on macOS):
{
"mcpServers": {
"falkordb": {
"command": "node",
"args": [
"/absolute/path/to/falkordb-mcpserver/dist/index.js"
]
}
}
}
Restart Claude Desktop and you'll see the FalkorDB tools available!
Once connected, you can ask Claude to:
"Show me all people who know each other"
"Find the shortest path between two nodes"
"What relationships does John have?"
"Create a new person named Alice who knows Bob"
"Add a 'WORKS_AT' relationship between Alice and TechCorp"
"Store my API key in the database"
"List all available graphs"
"Show me the structure of the user_data graph"
"Delete the old_test graph"
# Development with hot-reload
npm run dev
# Development with TypeScript execution (faster startup)
npm run dev:ts
# Run tests
npm test
# Run tests in watch mode
npm run test:watch
# Run tests with coverage report
npm run test:coverage
# Lint code
npm run lint
# Lint and auto-fix issues
npm run lint:fix
# Build for production
npm run build
# Start production server
npm start
# Inspect MCP server with debugging tools
npm run inspect
# Clean build artifacts
npm run clean
# Full CI pipeline (test, lint, build)
npm run prepublish
src/
βββ index.ts # MCP server entry point
βββ services/ # Core business logic
β βββ falkordb.service.ts # FalkorDB operations
β βββ redis.service.ts # Key-value operations
β βββ logger.service.ts # Logging and MCP notifications
βββ mcp/ # MCP protocol implementations
β βββ tools.ts # MCP tool definitions
β βββ resources.ts # MCP resource definitions
β βββ prompts.ts # MCP prompt definitions
βββ errors/ # Error handling framework
β βββ AppError.ts # Custom error classes
β βββ ErrorHandler.ts # Global error handling
βββ config/ # Configuration management
β βββ index.ts # Environment configuration
βββ models/ # TypeScript type definitions
β βββ mcp.types.ts # MCP protocol types
β βββ mcp-client-config.ts # Configuration models
βββ utils/ # Utility functions
βββ connection-parser.ts # Connection string parsing
For cloud-hosted FalkorDB instances:
FALKORDB_HOST=your-instance.falkordb.com
FALKORDB_PORT=6379
FALKORDB_USERNAME=your-username
FALKORDB_PASSWORD=your-secure-password
You can run multiple MCP servers for different FalkorDB instances:
{
"mcpServers": {
"falkordb-dev": {
"command": "node",
"args": ["path/to/server/dist/index.js"],
"env": {
"FALKORDB_HOST": "dev.falkordb.local"
}
},
"falkordb-prod": {
"command": "node",
"args": ["path/to/server/dist/index.js"],
"env": {
"FALKORDB_HOST": "prod.falkordb.com"
}
}
}
}
Here's what you can do once connected:
// Claude can help you write queries like:
MATCH (p:Person)-[:KNOWS]->(friend:Person)
WHERE p.name = 'Alice'
RETURN friend.name, friend.age
// Or create complex data structures:
CREATE (alice:Person {name: 'Alice', age: 30})
CREATE (bob:Person {name: 'Bob', age: 25})
CREATE (alice)-[:KNOWS {since: 2020}]->(bob)
// And even analyze your graph:
MATCH path = shortestPath((start:Person)-[*]-(end:Person))
WHERE start.name = 'Alice' AND end.name = 'Charlie'
RETURN path
We welcome contributions! Please see our Contributing Guidelines for details.
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
- Built on the Model Context Protocol SDK
- Powered by FalkorDB
- Inspired by the growing MCP ecosystem
Made with β€οΈ by the FalkorDB team & Katie Mulliken