Files
Memoh/docker-compose.yml
T
BBQ e63d335c7e feat(deploy): add containerd-in-docker support for docker compose
Run containerd as a sidecar container instead of requiring host
containerd installation. Server mounts shared docker volumes for
containerd socket, data and state.
2026-02-12 23:50:48 +08:00

155 lines
3.5 KiB
YAML

name: "memoh"
services:
postgres:
image: postgres:18-alpine
container_name: memoh-postgres
environment:
POSTGRES_DB: memoh
POSTGRES_USER: memoh
POSTGRES_PASSWORD: memoh123
volumes:
- postgres_data:/var/lib/postgresql
- ./db/migrations:/docker-entrypoint-initdb.d:ro
expose:
- "5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U memoh"]
interval: 10s
timeout: 5s
retries: 5
restart: unless-stopped
networks:
- memoh-network
qdrant:
image: qdrant/qdrant:latest
container_name: memoh-qdrant
volumes:
- qdrant_data:/qdrant/storage
expose:
- "6333"
- "6334"
healthcheck:
test: ["CMD-SHELL", "timeout 10s bash -c ':> /dev/tcp/127.0.0.1/6333' || exit 1"]
interval: 10s
timeout: 5s
retries: 5
restart: unless-stopped
networks:
- memoh-network
containerd:
image: docker.io/library/alpine:latest
container_name: memoh-containerd
entrypoint: ["/bin/sh", "-c"]
command:
- |
apk add --no-cache containerd containerd-ctr
mkdir -p /run/containerd
containerd
privileged: true
volumes:
- containerd_sock:/run/containerd
- containerd_data:/var/lib/containerd
- memoh_data:/opt/memoh/data
healthcheck:
test: ["CMD-SHELL", "test -S /run/containerd/containerd.sock"]
interval: 5s
timeout: 3s
retries: 10
start_period: 10s
restart: unless-stopped
networks:
- memoh-network
server:
build:
context: .
dockerfile: docker/Dockerfile.server
args:
- VERSION=${MEMOH_VERSION:-dev}
- COMMIT_HASH=${MEMOH_COMMIT:-unknown}
- BUILD_TIME=${MEMOH_BUILD_TIME:-unknown}
container_name: memoh-server
pid: host
volumes:
- ./config.toml:/app/config.toml:ro
- containerd_sock:/run/containerd
- containerd_data:/var/lib/containerd
- server_cni_state:/var/lib/cni
- memoh_data:/opt/memoh/data
cap_add:
- SYS_ADMIN
- NET_ADMIN
security_opt:
- seccomp:unconfined
- apparmor:unconfined
ports:
- "8080:8080"
depends_on:
postgres:
condition: service_healthy
qdrant:
condition: service_healthy
containerd:
condition: service_healthy
restart: unless-stopped
networks:
- memoh-network
agent:
build:
context: .
dockerfile: docker/Dockerfile.agent
container_name: memoh-agent
volumes:
- ./config.toml:/config.toml:ro
ports:
- "8081:8081"
healthcheck:
test: ["CMD-SHELL", "wget --no-verbose --tries=1 --spider http://127.0.0.1:8081/health || exit 1"]
interval: 10s
timeout: 5s
retries: 5
start_period: 20s
depends_on:
- server
restart: unless-stopped
networks:
- memoh-network
web:
build:
context: .
dockerfile: docker/Dockerfile.web
args:
- VITE_API_URL=http://localhost:8080
- VITE_AGENT_URL=http://localhost:8081
container_name: memoh-web
ports:
- "80:80"
depends_on:
- server
- agent
restart: unless-stopped
networks:
- memoh-network
volumes:
postgres_data:
driver: local
qdrant_data:
driver: local
containerd_sock:
driver: local
containerd_data:
driver: local
memoh_data:
driver: local
server_cni_state:
driver: local
networks:
memoh-network:
driver: bridge