Neo4j Aura数据库管理器
STDIONeo4j Aura数据库管理MCP服务器
Neo4j Aura数据库管理MCP服务器
A Model Context Protocol (MCP) server implementation that provides tools for managing Neo4j Aura database instances through the Neo4j Aura API.
This server allows you to create, monitor, and manage Neo4j Aura instances directly through Claude, making it easy to provision and maintain your graph database infrastructure.
Authentication with the Neo4j Aura API requires:
You can obtain these credentials from the Neo4j Aura console, see the documentation of the Aura API
Here is the API Specification
The server offers these core tools:
list_instances
get_instance_details
instance_ids (string or array): ID of the instance to retrieve, or array of instance IDsget_instance_by_name
name (string): Name of the instance to findcreate_instance
tenant_id (string): ID of the tenant/project where the instance will be createdname (string): Name for the new instancememory (integer): Memory allocation in GBregion (string): Region for the instance (e.g., 'us-east-1')version (string): Neo4j version (e.g., '5.15')type (string, optional): Instance type (enterprise or professional)vector_optimized (boolean, optional): Whether the instance is optimized for vector operationsupdate_instance_name
instance_id (string): ID of the instance to updatename (string): New name for the instanceupdate_instance_memory
instance_id (string): ID of the instance to updatememory (integer): New memory allocation in GBupdate_instance_vector_optimization
instance_id (string): ID of the instance to updatevector_optimized (boolean): Whether the instance should be optimized for vector operationspause_instance
instance_id (string): ID of the instance to pauseresume_instance
instance_id (string): ID of the instance to resumedelete_instance
tenant_id (string): ID of the tenant/project where the instance existsinstance_id (string): ID of the instance to deletelist_tenants
get_tenant_details
tenant_id (string): ID of the tenant/project to retrievepip install mcp-neo4j-aura-manager
Add the server to your claude_desktop_config.json:
"mcpServers": { "neo4j-aura": { "command": "uvx", "args": [ "[email protected]", "--client-id", "<your-client-id>", "--client-secret", "<your-client-secret>" ] } }
Alternatively, you can set environment variables:
"mcpServers": { "neo4j-aura": { "command": "uvx", "args": [ "[email protected]" ], "env": { "NEO4J_AURA_CLIENT_ID": "<your-client-id>", "NEO4J_AURA_CLIENT_SECRET": "<your-client-secret>" } } }
"mcpServers": { "neo4j-aura": { "command": "docker", "args": [ "run", "--rm", "-e", "NEO4J_AURA_CLIENT_ID=${NEO4J_AURA_CLIENT_ID}", "-e", "NEO4J_AURA_CLIENT_SECRET=${NEO4J_AURA_CLIENT_SECRET}", "mcp-neo4j-aura-manager:0.4.3" ] } }
The server supports namespacing to prefix tool names for multi-tenant deployments:
"mcpServers": { "neo4j-aura-app1": { "command": "uvx", "args": [ "[email protected]", "--client-id", "<your-client-id>", "--client-secret", "<your-client-secret>", "--namespace", "app1" ] }, "neo4j-aura-app2": { "command": "uvx", "args": [ "[email protected]", "--client-id", "<your-client-id>", "--client-secret", "<your-client-secret>", "--namespace", "app2" ] } }
# With namespace mcp-neo4j-aura-manager --client-id <id> --client-secret <secret> --namespace myapp # Tools become: myapp-list_instances, myapp-create_instance, etc.
export NEO4J_AURA_CLIENT_ID=your_client_id export NEO4J_AURA_CLIENT_SECRET=your_client_secret export NEO4J_NAMESPACE=myapp mcp-neo4j-aura-manager
docker run -e NEO4J_AURA_CLIENT_ID=<id> \ -e NEO4J_AURA_CLIENT_SECRET=<secret> \ -e NEO4J_NAMESPACE=myapp \ mcp-neo4j-aura-manager
The server supports HTTP transport for web-based deployments and microservices:
# Basic HTTP mode (defaults: host=127.0.0.1, port=8000, path=/mcp/) mcp-neo4j-aura-manager --transport http # Custom HTTP configuration mcp-neo4j-aura-manager --transport http --host 127.0.0.1 --port 8080 --path /api/mcp/
Environment variables for HTTP configuration:
export NEO4J_TRANSPORT=http export NEO4J_MCP_SERVER_HOST=127.0.0.1 export NEO4J_MCP_SERVER_PORT=8080 export NEO4J_MCP_SERVER_PATH=/api/mcp/ export NEO4J_MCP_SERVER_ALLOWED_HOSTS="localhost,127.0.0.1" export NEO4J_MCP_SERVER_ALLOW_ORIGINS="http://localhost:3000" export NEO4J_NAMESPACE=myapp mcp-neo4j-aura-manager
The server supports three transport modes:
The server includes comprehensive security protection with secure defaults that protect against common web-based attacks while preserving full MCP functionality when using HTTP transport.
TrustedHost Middleware validates Host headers to prevent DNS rebinding attacks:
Secure by Default:
localhost and 127.0.0.1 hosts are allowed by defaultEnvironment Variable:
export NEO4J_MCP_SERVER_ALLOWED_HOSTS="example.com,www.example.com"
Cross-Origin Resource Sharing (CORS) protection blocks browser-based requests by default:
Environment Variable:
export NEO4J_MCP_SERVER_ALLOW_ORIGINS="https://example.com,https://example.com"
Development Setup:
mcp-neo4j-aura-manager --transport http \ --allowed-hosts "localhost,127.0.0.1" \ --allow-origins "http://localhost:3000"
Production Setup:
mcp-neo4j-aura-manager --transport http \ --allowed-hosts "example.com,www.example.com" \ --allow-origins "https://example.com,https://example.com"
For allow_origins:
["https://example.com", "https://example.com"]"*" in production with credentialsFor allowed_hosts:
["example.com", "www.example.com"]"*" unless you understand the risksThe Neo4j Aura Manager MCP server can be deployed using Docker for remote deployments. Docker deployment should use HTTP transport for web accessibility. In order to integrate this deployment with applications like Claude Desktop, you will have to use a proxy in your MCP configuration such as mcp-remote.
Here we use the Docker Hub hosted Aura Manager MCP server image with stdio transport for use with Claude Desktop.
Config details:
-i: Interactive mode - keeps STDIN open for stdio transport communication--rm: Automatically remove container when it exits (cleanup)-p 8000:8000: Port mapping - maps host port 8000 to container port 8000NEO4J_TRANSPORT=stdio: Uses stdio transport for Claude Desktop compatibilityNEO4J_AURA_CLIENT_ID and NEO4J_AURA_CLIENT_SECRET: Your Aura API credentials{ "mcpServers": { "neo4j-aura": { "command": "docker", "args": [ "run", "-i", "--rm", "-p", "8000:8000", "-e", "NEO4J_AURA_CLIENT_ID=your-client-id", "-e", "NEO4J_AURA_CLIENT_SECRET=your-client-secret", "-e", "NEO4J_TRANSPORT=stdio", "mcp/neo4j-aura-manager:latest" ] } } }
After building locally with docker build -t mcp-neo4j-aura-manager:latest .:
# Build the image docker build -t mcp-neo4j-aura-manager:<version> . # Run with http transport (default for Docker) docker run --rm -p 8000:8000 \ -e NEO4J_AURA_CLIENT_ID="your-client-id" \ -e NEO4J_AURA_CLIENT_SECRET="your-client-secret" \ -e NEO4J_TRANSPORT="http" \ -e NEO4J_MCP_SERVER_HOST="0.0.0.0" \ -e NEO4J_MCP_SERVER_PORT="8000" \ -e NEO4J_MCP_SERVER_PATH="/mcp/" \ mcp-neo4j-aura-manager:<version> # Run with security middleware for production docker run --rm -p 8000:8000 \ -e NEO4J_AURA_CLIENT_ID="your-client-id" \ -e NEO4J_AURA_CLIENT_SECRET="your-client-secret" \ -e NEO4J_TRANSPORT="http" \ -e NEO4J_MCP_SERVER_HOST="0.0.0.0" \ -e NEO4J_MCP_SERVER_PORT="8000" \ -e NEO4J_MCP_SERVER_PATH="/mcp/" \ -e NEO4J_MCP_SERVER_ALLOWED_HOSTS="example.com,www.example.com" \ -e NEO4J_MCP_SERVER_ALLOW_ORIGINS="https://example.com" \ mcp-neo4j-aura-manager:<version>
| Variable | Default | Description | 
|---|---|---|
NEO4J_AURA_CLIENT_ID | (none) | Neo4j Aura API Client ID | 
NEO4J_AURA_CLIENT_SECRET | (none) | Neo4j Aura API Client Secret | 
NEO4J_TRANSPORT | stdio (local), http (remote) | Transport protocol (stdio, http, or sse) | 
NEO4J_MCP_SERVER_HOST | 127.0.0.1 (local) | Host to bind to | 
NEO4J_MCP_SERVER_PORT | 8000 | Port for HTTP/SSE transport | 
NEO4J_MCP_SERVER_PATH | /mcp/ | Path for accessing MCP server | 
NEO4J_MCP_SERVER_ALLOW_ORIGINS | (empty - secure by default) | Comma-separated list of allowed CORS origins | 
NEO4J_MCP_SERVER_ALLOWED_HOSTS | localhost,127.0.0.1 | Comma-separated list of allowed hosts (DNS rebinding protection) | 
NEO4J_NAMESPACE | (empty - no prefix) | Namespace prefix for tool names (e.g., myapp-list_instances) | 
When using SSE transport (for legacy web clients), the server exposes an HTTP endpoint:
# Start the server with SSE transport docker run -d -p 8000:8000 \ -e NEO4J_AURA_CLIENT_ID="your-client-id" \ -e NEO4J_AURA_CLIENT_SECRET="your-client-secret" \ -e NEO4J_TRANSPORT="sse" \ -e NEO4J_MCP_SERVER_HOST="0.0.0.0" \ -e NEO4J_MCP_SERVER_PORT="8000" \ --name neo4j-aura-mcp-server \ mcp-neo4j-aura-manager:latest # Test the SSE endpoint curl http://localhost:8000/sse # Use with MCP Inspector npx @modelcontextprotocol/inspector http://localhost:8000/sse
For Claude Desktop integration with a Dockerized server using http transport:
{ "mcpServers": { "neo4j-aura-docker": { "command": "npx", "args": ["-y", "mcp-remote@latest", "http://localhost:8000/mcp/"] } } }
Note: First start your Docker container with HTTP transport, then Claude Desktop can connect to it via the HTTP endpoint and proxy server like mcp-remote.





uv (Universal Virtualenv):# Using pip pip install uv # Using Homebrew on macOS brew install uv # Using cargo (Rust package manager) cargo install uv
# Clone the repository git clone https://github.com/yourusername/mcp-neo4j-aura-manager.git cd mcp-neo4j-aura-manager # Create and activate virtual environment using uv uv venv source .venv/bin/activate # On Unix/macOS .venv\Scripts\activate # On Windows # Install dependencies including dev dependencies uv pip install -e ".[dev]"
This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.