This guide explains how to run LiteGraph Server using Docker containers.
Docker Hub
The official LiteGraph Docker image is available at:
- Docker Hub: https://hub.docker.com/r/jchristn/litegraph
- Repository: https://github.com/litegraphdb/LiteGraph
Prerequisites
- Docker installed and running
- Docker Compose (optional, for compose deployment)
- Basic understanding of Docker volumes and networking
Quick Start with Docker Run
Basic Run Command
docker run -d \
  -p 8701:8701 \
  -v $(pwd)/litegraph.json:/app/litegraph.json \
  -v $(pwd)/litegraph.db:/app/litegraph.db \
  jchristn/litegraph:v4.0.0Interactive Mode with Full Persistence
docker run \
  -p 8701:8701 \
  -t \
  -i \
  -e "TERM=xterm-256color" \
  -v ./litegraph.json:/app/litegraph.json \
  -v ./litegraph.db:/app/litegraph.db \
  -v ./logs/:/app/logs/ \
  -v ./backups/:/app/backups/ \
  jchristn/litegraph:v4.0.0Using the Provided Scripts
LiteGraph includes helper scripts for running the container:
Linux/macOS (run.sh)
# Run with default tag (v3.1.0)
./run.sh
# Run with specific tag
IMG_TAG=v4.1.0 ./run.shWindows (run.bat)
REM Run with specific tag
run.bat v4.1.0Docker Compose Deployment
Using Docker Compose
The repository includes a compose.yaml file for easy deployment:
services:
  litegraph:
    container_name: 'litegraph'
    image: 'jchristn/litegraph:v4.1.0'
    network_mode: 'host'
    stdin_open: true
    tty: true
    volumes:
      - ./litegraph.json:/app/litegraph.json
      - ./litegraph.db:/app/litegraph.db
      - ./logs/:/app/logs/
      - ./backups/:/app/backups/
    healthcheck:
      test: curl --fail http://localhost:8701Start with Docker Compose
Linux/macOS:
./compose-up.shWindows:
compose-up.batOr manually:
docker compose -f compose.yaml up -dStop with Docker Compose
Linux/macOS:
./compose-down.shWindows:
compose-down.batOr manually:
docker compose -f compose.yaml downVolume Mounts
LiteGraph requires several volumes for persistence:
| Local Path | Container Path | Purpose | 
|---|---|---|
| ./litegraph.json | /app/litegraph.json | Configuration file | 
| ./litegraph.db | /app/litegraph.db | SQLite database | 
| ./logs/ | /app/logs/ | Log files | 
| ./backups/ | /app/backups/ | Database backups | 
Important: Ensure these files/directories exist before running the container, especially litegraph.json.
Initial Setup
1. Create Configuration File
If you don't have a litegraph.json file, create one, or refer to the default litegraph.json in the docker folder in the Github repository:
{
  "Logging": {
    "ConsoleLogging": true,
    "LogDirectory": "./logs/",
    "LogFilename": "litegraph.log"
  },
  "Rest": {
    "Hostname": "*",
    "Port": 8701
  },
  "LiteGraph": {
    "AdminBearerToken": "litegraphadmin",
    "GraphRepositoryFilename": "litegraph.db",
    "InMemory": false
  }
}2. First Run
On first run with a new database, the container will create default records:
- Default tenant: 00000000-0000-0000-0000-000000000000
- Default user: [email protected]/password
- Default credential bearer token: default
- Default graph: 00000000-0000-0000-0000-000000000000
Networking Options
Host Network Mode (Default in compose.yaml)
network_mode: 'host'The container uses the host's network directly. Access at http://localhost:8701.
Bridge Network Mode
docker run -d \
  -p 8701:8701 \
  jchristn/litegraph:v4.0.0Maps container port 8701 to host port 8701.
Custom Port Mapping
docker run -d \
  -p 9000:8701 \
  jchristn/litegraph:v4.0.0Access at http://localhost:9000.
Health Checks
The Docker Compose configuration includes a health check:
healthcheck:
  test: curl --fail http://localhost:8701Check container health:
docker ps
docker inspect litegraph --format='{{.State.Health.Status}}'Container Management
View Logs
# Follow logs
docker logs -f litegraph
# Last 100 lines
docker logs --tail 100 litegraphAccess Container Shell
docker exec -it litegraph /bin/bashStop Container
docker stop litegraphRemove Container
docker rm litegraphEnvironment Variables
The container respects environment variables for configuration:
docker run -d \
  -e TERM=xterm-256color \
  -p 8701:8701 \
  jchristn/litegraph:v4.0.0Updating the Image
Pull Latest Version
docker pull jchristn/litegraph:v4.1.0Update Running Container
- Stop and remove the existing container:
docker stop litegraph
docker rm litegraph- Run with the new image:
docker run -d \
  -p 8701:8701 \
  -v $(pwd)/litegraph.json:/app/litegraph.json \
  -v $(pwd)/litegraph.db:/app/litegraph.db \
  jchristn/litegraph:v4.1.0Production Considerations
Data Persistence
Always mount volumes for:
- Configuration (litegraph.json)
- Database (litegraph.db)
- Logs (./logs/)
- Backups (./backups/)
Troubleshooting
Container Won't Start
Check logs:
docker logs litegraphVerify volume mounts:
ls -la litegraph.json litegraph.dbCannot Access from Host
Verify port mapping:
docker port litegraphCheck if service is running:
docker exec litegraph curl -I http://localhost:8701Permission Issues
Ensure proper file permissions:
chmod 644 litegraph.json
chmod 644 litegraph.db
chmod 755 logs/ backups/Database Locked
If database is locked, stop all containers accessing it:
docker stop litegraph
# Wait a moment
docker start litegraphTesting the Deployment
Health Check
curl -I http://localhost:8701/API Test with Default Credentials
curl -H "Authorization: Bearer default" \
     http://localhost:8701/v1.0/tenants/00000000-0000-0000-0000-000000000000/graphsCreate Test Data
curl -X PUT \
     -H "Authorization: Bearer default" \
     -H "Content-Type: application/json" \
     -d '{"Name": "Docker Test Node"}' \
     http://localhost:8701/v1.0/tenants/00000000-0000-0000-0000-000000000000/graphs/00000000-0000-0000-0000-000000000000/nodes