102 lines
2.9 KiB
YAML
102 lines
2.9 KiB
YAML
################################
|
|
# 🦎 KOMODO COMPOSE - MONGO 🦎 #
|
|
################################
|
|
|
|
## This compose file will deploy:
|
|
## 1. MongoDB
|
|
## 2. Komodo Core
|
|
## 3. Komodo Periphery
|
|
|
|
services:
|
|
mongo:
|
|
image: mongo
|
|
labels:
|
|
komodo.skip: # Prevent Komodo from stopping with StopAllContainers
|
|
command: --quiet --wiredTigerCacheSizeGB 0.25
|
|
restart: unless-stopped
|
|
logging:
|
|
driver: ${COMPOSE_LOGGING_DRIVER:-local}
|
|
networks:
|
|
- default
|
|
# ports:
|
|
# - 27017:27017
|
|
volumes:
|
|
- mongo-data:/data/db
|
|
- mongo-config:/data/configdb
|
|
environment:
|
|
MONGO_INITDB_ROOT_USERNAME: ${DB_USERNAME}
|
|
MONGO_INITDB_ROOT_PASSWORD: ${DB_PASSWORD}
|
|
|
|
core:
|
|
image: ghcr.io/mbecker20/komodo:${COMPOSE_KOMODO_IMAGE_TAG:-latest}
|
|
labels:
|
|
komodo.skip: # Prevent Komodo from stopping with StopAllContainers
|
|
restart: unless-stopped
|
|
depends_on:
|
|
- mongo
|
|
logging:
|
|
driver: ${COMPOSE_LOGGING_DRIVER:-local}
|
|
networks:
|
|
- default
|
|
ports:
|
|
- 9120:9120
|
|
env_file: .env
|
|
environment:
|
|
KOMODO_DATABASE_ADDRESS: mongo:27017
|
|
KOMODO_DATABASE_USERNAME: ${DB_USERNAME}
|
|
KOMODO_DATABASE_PASSWORD: ${DB_PASSWORD}
|
|
volumes:
|
|
## Core cache for repos for latest commit hash / contents
|
|
- repo-cache:/repo-cache
|
|
## Store sync files on server
|
|
# - /path/to/syncs:/syncs
|
|
## Optionally mount a custom core.config.toml
|
|
# - /path/to/core.config.toml:/config/config.toml
|
|
## Allows for systemd Periphery connection at
|
|
## "http://host.docker.internal:8120"
|
|
# extra_hosts:
|
|
# - host.docker.internal:host-gateway
|
|
|
|
## Deploy Periphery container using this block,
|
|
## or deploy the Periphery binary with systemd using
|
|
## https://github.com/mbecker20/komodo/tree/main/scripts
|
|
periphery:
|
|
image: ghcr.io/mbecker20/periphery:${COMPOSE_KOMODO_IMAGE_TAG:-latest}
|
|
labels:
|
|
komodo.skip: # Prevent Komodo from stopping with StopAllContainers
|
|
restart: unless-stopped
|
|
logging:
|
|
driver: ${COMPOSE_LOGGING_DRIVER:-local}
|
|
networks:
|
|
- default
|
|
env_file: .env
|
|
volumes:
|
|
## Mount external docker socket
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
## Allow Periphery to see processes outside of container
|
|
- /proc:/proc
|
|
## use self signed certs in docker volume,
|
|
## or mount your own signed certs.
|
|
- ssl-certs:/etc/komodo/ssl
|
|
## manage repos in a docker volume,
|
|
## or change it to an accessible host directory.
|
|
- repos:/etc/komodo/repos
|
|
## manage stack files in a docker volume,
|
|
## or change it to an accessible host directory.
|
|
- stacks:/etc/komodo/stacks
|
|
## Optionally mount a path to store compose files
|
|
# - /path/to/compose:/host/compose
|
|
|
|
volumes:
|
|
# Mongo
|
|
mongo-data:
|
|
mongo-config:
|
|
# Core
|
|
repo-cache:
|
|
# Periphery
|
|
ssl-certs:
|
|
repos:
|
|
stacks:
|
|
|
|
networks:
|
|
default: {} |