Files
mrva-docker/docker-compose-demo.yml
michael hohn 13a065545e Standardize container build workflow for v0.4.5
- Build Go binaries (gh-mrva, mrvaserver, mrvaagent) in source repos before
  copying to container dirs

- Apply consistent v0.4.5 tagging across all containers (ghmrva, vscode,
  hepc, server, agent)

- Update hepc to sync mrvahepc source with venv and .git exclusions

- Verify deployment with docker-compose-demo.yml and bin/ma.send-request
  tests
2025-11-26 12:39:59 -08:00

152 lines
4.3 KiB
YAML

services:
mrvastore-init:
image: minio/mc
container_name: mrvastore-init
depends_on:
- mrvastore
networks:
- backend
env_file: .env.container
# entrypoint: ["tail", "-f", "/dev/null"]
entrypoint: >
/bin/sh -c "
set -e;
until mc alias set local http://mrvastore:9000 $${MINIO_ROOT_USER} $${MINIO_ROOT_PASSWORD}; do
echo 'Waiting for MinIO...'; sleep 1;
done;
mc mb -p local/mrvabucket;
"
mrvastore:
image: minio/minio:RELEASE.2024-06-11T03-13-30Z
container_name: mrvastore
hostname: mrvastore
ports:
- "9000:9000"
- "9001:9001"
env_file: .env.container
command: server /data/mrvacommander/mrvastore-data --console-address ":9001"
networks:
backend:
aliases:
- minio.store
- mrvabucket.minio.store
- packs.minio.store
- qldb.minio.store
- results.minio.store
client-ghmrva:
# ./containers/ghmrva/Dockerfile
container_name: mrva-ghmrva
image: mrva-gh-mrva:0.4.5
network_mode: "service:server" # Share the 'server' network namespace
environment:
- SERVER_URL=http://localhost:8080 # 'localhost' now refers to 'server'
- MRVA_SERVER_URL=http://server:8080
code-server:
# ./containers/vscode/Dockerfile
container_name: mrva-code-server
image: code-server-initialized:0.4.5
ports:
- "9080:9080"
# XX: Include codeql binary in code-server (if it's not there already)
networks:
- backend
environment:
- PASSWORD=mrva
hepc:
# ./containers/hepc/Dockerfile
image: mrva-hepc-container:0.4.5
container_name: mrva-hepc
hostname: hepc
command: >-
mc-hepc-serve --codeql-db-dir db-collection.tmp
--host "0.0.0.0"
--port "8070"
networks:
- backend
environment:
- MRVA_HEPC_ENDPOINT=http://hepc:8070
rabbitmq:
image: rabbitmq:3-management
hostname: rabbitmq
container_name: mrva-rabbitmq
volumes:
- ./init/rabbitmq/rabbitmq.conf:/etc/rabbitmq/rabbitmq.conf:ro
- ./init/rabbitmq/definitions.json:/etc/rabbitmq/definitions.json:ro
ports:
- "5672:5672"
- "15672:15672"
healthcheck:
test: rabbitmq-diagnostics check_port_connectivity
interval: 30s
timeout: 30s
retries: 10
networks:
- backend
server:
# ./containers/server/Dockerfile
image: mrva-server:0.4.5
command: [ '--mode=container', '--loglevel=debug' ]
container_name: mrva-server
hostname: server
stop_grace_period: 1s
depends_on:
- rabbitmq
- mrvastore
- postgres
env_file: ./.env.container
environment:
POSTGRES_USER: mrva
POSTGRES_PASSWORD: mrvapg
POSTGRES_DB: mrvadb
POSTGRES_HOST: postgres
POSTGRES_PORT: 5432
MRVA_HEPC_ENDPOINT: http://hepc:8070
MRVA_HEPC_CACHE_DURATION: "60"
SERVER_HOST: server
SERVER_PORT: "8080"
networks:
- backend
postgres:
image: postgres:15
container_name: mrva-postgres
restart: unless-stopped
environment:
POSTGRES_USER: mrva
POSTGRES_PASSWORD: mrvapg
POSTGRES_DB: mrvadb
volumes:
- pgdata:/var/lib/postgresql/data
networks:
- backend
agent:
# ./containers/agent/Dockerfile
image: mrva-agent:0.4.5
command: [ '--loglevel=debug' ]
container_name: mrva-agent
hostname: agent
depends_on:
- rabbitmq
- mrvastore
env_file: ./.env.container
environment:
- MRVA_HEPC_ENDPOINT=http://hepc:8070
- MRVA_HEPC_CACHE_DURATION=60
networks:
- backend
networks:
backend:
driver: bridge
volumes:
pgdata: