mcp_server/docker/README-falkordb-combined.md
This Docker setup bundles FalkorDB (graph database) and the Graphiti MCP Server into a single container image for simplified deployment.
The combined image extends the official FalkorDB Docker image to include:
Both services are managed by a startup script that launches FalkorDB as a daemon and the MCP server in the foreground.
.env file in the mcp_server directory:# Required
OPENAI_API_KEY=your_openai_api_key
# Optional
GRAPHITI_GROUP_ID=main
SEMAPHORE_LIMIT=10
FALKORDB_PASSWORD=
cd mcp_server
docker compose -f docker/docker-compose-falkordb-combined.yml up
docker run -d \
-p 6379:6379 \
-p 3000:3000 \
-p 8000:8000 \
-e OPENAI_API_KEY=your_key \
-e GRAPHITI_GROUP_ID=main \
-v falkordb_data:/var/lib/falkordb/data \
zepai/graphiti-falkordb:latest
docker compose -f docker/docker-compose-falkordb-combined.yml build
GRAPHITI_CORE_VERSION=0.22.0 docker compose -f docker/docker-compose-falkordb-combined.yml build
GRAPHITI_CORE_VERSION: Version of graphiti-core package (default: 0.22.0)MCP_SERVER_VERSION: MCP server version tag (default: 1.0.0rc0)BUILD_DATE: Build timestampVCS_REF: Git commit hashAll environment variables from the standard MCP server are supported:
Required:
OPENAI_API_KEY: OpenAI API key for LLM operationsOptional:
BROWSER: Enable FalkorDB Browser web UI on port 3000 (default: "1", set to "0" to disable)GRAPHITI_GROUP_ID: Namespace for graph data (default: "main")SEMAPHORE_LIMIT: Concurrency limit for episode processing (default: 10)FALKORDB_PASSWORD: Password for FalkorDB (optional)FALKORDB_DATABASE: FalkorDB database name (default: "default_db")Other LLM Providers:
ANTHROPIC_API_KEY: For Claude modelsGOOGLE_API_KEY: For Gemini modelsGROQ_API_KEY: For Groq models/var/lib/falkordb/data: Persistent storage for graph data/var/log/graphiti: MCP server and FalkorDB Browser logs# All logs (both services stdout/stderr)
docker compose -f docker/docker-compose-falkordb-combined.yml logs -f
# Only container logs
docker compose -f docker/docker-compose-falkordb-combined.yml logs -f graphiti-falkordb
# Restart entire container (both services)
docker compose -f docker/docker-compose-falkordb-combined.yml restart
# Check FalkorDB status
docker compose -f docker/docker-compose-falkordb-combined.yml exec graphiti-falkordb redis-cli ping
# Check MCP server status
curl http://localhost:8000/health
To disable the FalkorDB Browser web UI (port 3000), set the BROWSER environment variable to 0:
# Using docker run
docker run -d \
-p 6379:6379 \
-p 3000:3000 \
-p 8000:8000 \
-e BROWSER=0 \
-e OPENAI_API_KEY=your_key \
zepai/graphiti-falkordb:latest
# Using docker-compose
# Add to your .env file:
BROWSER=0
When disabled, only FalkorDB (port 6379) and the MCP server (port 8000) will run.
The container includes a health check that verifies:
Check health status:
docker compose -f docker/docker-compose-falkordb-combined.yml ps
start-services.sh (PID 1)
├── redis-server (FalkorDB daemon)
├── node server.js (FalkorDB Browser - background, if BROWSER=1)
└── uv run main.py (MCP server - foreground)
The startup script launches FalkorDB as a background daemon, waits for it to be ready, optionally starts the FalkorDB Browser (if BROWSER=1), then starts the MCP server in the foreground. When the MCP server stops, the container exits.
/app/mcp/ # MCP server application
├── main.py
├── src/
├── config/
│ └── config.yaml # FalkorDB-specific configuration
└── .graphiti-core-version # Installed version info
/var/lib/falkordb/data/ # Persistent graph storage
/var/lib/falkordb/browser/ # FalkorDB Browser web UI
/var/log/graphiti/ # MCP server and Browser logs
/start-services.sh # Startup script
Check container logs:
docker compose -f docker/docker-compose-falkordb-combined.yml logs graphiti-falkordb
docker compose -f docker/docker-compose-falkordb-combined.yml exec graphiti-falkordb redis-cli ping
curl http://localhost:8000/health
docker compose -f docker/docker-compose-falkordb-combined.yml logs -f
If ports 6379, 3000, or 8000 are already in use, modify the port mappings in docker-compose-falkordb-combined.yml:
ports:
- "16379:6379" # Use different external port
- "13000:3000"
- "18000:8000"
deploy:
resources:
limits:
cpus: '2'
memory: 4G
/var/lib/falkordb/data volumeFALKORDB_PASSWORD in production environments| Aspect | Combined Image | Separate Containers |
|---|---|---|
| Setup Complexity | Simple (one container) | Moderate (service dependencies) |
| Network Latency | Lower (localhost) | Higher (container network) |
| Resource Usage | Lower (shared base) | Higher (separate images) |
| Scalability | Limited | Better (scale independently) |
| Debugging | Harder (multiple processes) | Easier (isolated services) |
| Production Use | Development/Single-node | Recommended |