tacticalrmm/docker/docker-compose.yml

95 lines
1.8 KiB
YAML

version: '3.7'
# Userdefined Networks
networks:
database:
redis:
mesh-mongodb:
proxy:
driver: bridge
ipam:
driver: default
config:
- subnet: 172.20.0.0/24
# Docker managed persistent volumes
volumes:
# Volume for userdefined scripts
scripts:
services:
# Postgres Database for API service
db:
image: postgres:11.7
environment:
POSTGRES_DB: tacticalrmm
POSTGRES_USER: ${POSTGRES_USER}
POSTGRES_PASSWORD: ${POSTGRES_PASS}
networks:
- database
# Redis Container for Celery tasks
redis:
image: redis
networks:
- redis
# Salt Master and API
salt:
build:
context: ..
dockerfile: ./docker/salt/dockerfile
args:
- SALT_USER=${SALT_USER}
- SALT_PASS=${SALT_PASS}
ports:
- "8123:8123"
- "4505:4505"
- "4506:4506"
volumes:
- scripts:/srv
networks:
- proxy
# MeshCentral Container
meshcentral:
build:
context: ./meshcentral
args:
- MESH_HOST=${MESH_HOST}
- MONGODB_USER=${MONGODB_USER}
- MONGODB_PASSWORD=${MONGODB_PASSWORD}
networks:
- proxy
- mesh-mongodb
depends_on:
- mesh-mongodb
- nginx-proxy
# MongoDB Container for MeshCentral
mesh-mongodb:
image: mongo
environment:
MONGO_INITDB_ROOT_USERNAME: ${MONGODB_USER}
MONGO_INITDB_ROOT_PASSWORD: ${MONGODB_PASSWORD}
MONGO_INITDB_DATABASE: meshcentral
networks:
- mesh-mongodb
# Nginx Container Reverse Proxy that handles all http/https traffic
nginx-proxy:
build:
context: ./nginx-proxy
args:
- APP_HOST=${APP_HOST}
- API_HOST=${API_HOST}
- MESH_HOST=${MESH_HOST}
ports:
- "80:80"
- "443:443"
networks:
proxy:
ipv4_address: 172.20.0.20