Files
mrva-docker/docker-compose-demo.yml

152 lines
4.5 KiB
YAML

services:
dbssvc:
# ./containers/dbsdata/Dockerfile
image: ghcr.io/hohn/dbsdata-container:0.1.24
command: tail -f /dev/null # Keep the container running
# volumes:
# - /qldb # Directory inside the container that contains the data
volumes:
- dbsdata:/data
container_name: mrva-dbssvc
hostname: dbssvc
networks:
- backend
dbstore:
image: minio/minio:RELEASE.2024-06-11T03-13-30Z
container_name: mrva-dbstore
hostname: dbstore
ports:
- "9000:9000"
- "9001:9001"
env_file:
- path: .env.container
required: true
command: server /data/mrvacommander/dbstore-data --console-address ":9001"
depends_on:
- dbssvc
# volumes_from:
# - dbsdata # Use the volumes from dbsdata container
volumes:
- dbsdata:/data/mrvacommander/dbstore-data
networks:
- backend
client-ghmrva:
# ./containers/ghmrva/Dockerfile
container_name: mrva-ghmrva
image: ghcr.io/hohn/client-ghmrva-container:0.1.24
network_mode: "service:server" # Share the 'server' network namespace
environment:
- SERVER_URL=http://localhost:8080 # 'localhost' now refers to 'server'
code-server:
# ./containers/vscode/Dockerfile
container_name: mrva-code-server
image: code-server-initialized:0.3.3
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: ghcr.io/hohn/mrva-hepc-container:0.1.24
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: ghcr.io/hohn/mrva-server:0.1.24
command: [ '--mode=container', '--loglevel=debug' ]
container_name: mrva-server
hostname: server
stop_grace_period: 1s
depends_on:
- rabbitmq
- dbstore
- artifactstore
env_file:
- path: ./.env.container
required: true
environment:
- MRVA_HEPC_ENDPOINT=http://hepc:8070
- MRVA_HEPC_CACHE_DURATION=60
- SERVER_HOST=server
- SERVER_PORT=8080
networks:
- backend
artifactstore:
image: minio/minio:RELEASE.2024-06-11T03-13-30Z
container_name: mrva-artifactstore
hostname: artifactstore
ports:
- "19000:9000" # host:container
- "19001:9001"
env_file:
- path: ./.env.container
required: true
command: server /data --console-address ":9001"
volumes:
# The artifactstore is only populated at runtime so there is no need
# for Docker storage; a directory is fine.
- ./qpstore-data:/data
networks:
- backend
agent:
# ./containers/agent/Dockerfile
image: ghcr.io/hohn/mrva-agent:0.1.24
command: [ '--loglevel=debug' ]
container_name: mrva-agent
hostname: agent
depends_on:
- rabbitmq
- dbstore
- artifactstore
env_file:
- path: ./.env.container
required: true
environment:
- MRVA_HEPC_ENDPOINT=http://hepc:8070
- MRVA_HEPC_CACHE_DURATION=60
networks:
- backend
networks:
backend:
driver: bridge
volumes:
dbsdata: