254 lines
7.7 KiB
YAML
254 lines
7.7 KiB
YAML
#============== MIH Network ====================================================================
|
|
networks:
|
|
MIH_Network:
|
|
driver: bridge
|
|
services:
|
|
#============== Nginx Proxy Server Old ====================================================================
|
|
# nginx:
|
|
# container_name: nginx
|
|
# restart: unless-stopped
|
|
# image: nginx
|
|
# ports:
|
|
# - 80:80
|
|
# - 443:443
|
|
# volumes:
|
|
# - ./nginx/nginx.conf:/etc/nginx/nginx.conf
|
|
# - certbotConf:/etc/letsencrypt
|
|
# - certbotChall:/var/www/certbot
|
|
# depends_on:
|
|
# - MIH_UX
|
|
# networks:
|
|
# - MIH_Network
|
|
# profiles: [ 'prod' ]
|
|
#============== Cert Bot Old ====================================================================
|
|
# certbot:
|
|
# image: certbot/certbot
|
|
# container_name: certbot
|
|
# volumes:
|
|
# - certbotConf:/etc/letsencrypt
|
|
# - certbotChall:/var/www/certbot
|
|
# #command: certonly --test-cert --webroot -w /var/www/certbot --force-renewal --email yasienmeth@gmail.com -d mzansi-innovation-hub.co.za -d www.mzansi-innovation-hub.co.za --agree-tos
|
|
# command: certonly --webroot -w /var/www/certbot --force-renewal --email ${CERTBOT_EMAIL} -d ${CERTBOT_APP_DOMAIN} -d ${CERTBOT_API_DOMAIN} -d ${CERTBOT_STORAGE_DOMAIN} -d ${CERTBOT_MONITOR_DOMAIN} -d ${CERTBOT_AI_DOMAIN} --agree-tos
|
|
# networks:
|
|
# - MIH_Network
|
|
# depends_on:
|
|
# - nginx
|
|
# profiles: [ 'withCert' ]
|
|
#============== Nginx Proxy Manager ====================================================================
|
|
MIH_NGINX:
|
|
container_name: MIH_NGINX
|
|
image: 'jc21/nginx-proxy-manager:latest'
|
|
restart: unless-stopped
|
|
ports:
|
|
- '80:80' # Public HTTP
|
|
- '443:443' # Public HTTPS
|
|
- '81:81' # Admin Web Port
|
|
volumes:
|
|
- ./mih_nginx/data:/data
|
|
- ./mih_nginx/letsencrypt:/etc/letsencrypt
|
|
networks:
|
|
- MIH_Network
|
|
#============== GITEA ====================================================================
|
|
MIH_GITEA:
|
|
image: gitea/gitea:latest
|
|
container_name: MIH_GITEA
|
|
environment:
|
|
- USER_UID=1000
|
|
- USER_GID=1000
|
|
- GITEA__database__DB_TYPE=mysql
|
|
- GITEA__database__HOST=MIH-GITEA-DB:3306
|
|
- GITEA__database__NAME=gitea
|
|
- GITEA__database__USER=gitea
|
|
- GITEA__database__PASSWD=gitea_password
|
|
restart: always
|
|
networks:
|
|
- MIH_Network
|
|
volumes:
|
|
- ./mih_git/gitea:/data
|
|
- /etc/timezone:/etc/timezone:ro
|
|
- /etc/localtime:/etc/localtime:ro
|
|
ports:
|
|
- "3000:3000"
|
|
- "222:22"
|
|
depends_on:
|
|
MIH-GITEA-DB:
|
|
condition: service_healthy
|
|
MIH_GITEA_DB:
|
|
image: mysql:8.0
|
|
container_name: MIH_GITEA_DB
|
|
restart: always
|
|
environment:
|
|
- MYSQL_ROOT_PASSWORD=gitea_root_password
|
|
- MYSQL_USER=gitea
|
|
- MYSQL_PASSWORD=gitea_password
|
|
- MYSQL_DATABASE=gitea
|
|
networks:
|
|
- MIH_Network
|
|
volumes:
|
|
- ./mih_git/mysql:/var/lib/mysql
|
|
healthcheck:
|
|
test: ["CMD", "mysqladmin", "ping", "-h", "localhost"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
#============== Super Token Auth ====================================================================
|
|
MIH_SuperTokens:
|
|
container_name: MIH_SuperTokens
|
|
image: supertokens/supertokens-mysql:latest
|
|
# image: registry.supertokens.io/supertokens/supertokens-mysql
|
|
depends_on:
|
|
- MIH_DB
|
|
ports:
|
|
- 3567:3567
|
|
environment:
|
|
REFRESH_TOKEN_VALIDITY: '604800'
|
|
ACCESS_TOKEN_VALIDITY: '86400'
|
|
PASSWORD_RESET_TOKEN_LIFETIME: '7200000'
|
|
MYSQL_USER: ${SQL_USER}
|
|
MYSQL_PASSWORD: ${SQL_USER_PW}
|
|
MYSQL_HOST: MIH_DB
|
|
MYSQL_PORT: 3306
|
|
MYSQL_DATABASE_NAME: ${SUPERTOKENS_DB}
|
|
API_KEYS: ${SUPERTOKENS_API_KEY}
|
|
networks:
|
|
- MIH_Network
|
|
restart: unless-stopped
|
|
healthcheck:
|
|
test: >
|
|
bash -c 'exec 3<>/dev/tcp/127.0.0.1/3567 && echo -e "GET /hello HTTP/1.1\r\nhost: 127.0.0.1:3567\r\nConnection: close\r\n\r\n" >&3 && cat <&3 | grep "Hello"'
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
#============== MIH-UX Flutter ====================================================================
|
|
MIH_UX:
|
|
container_name: MIH_UX
|
|
build:
|
|
context: ./mih_ui
|
|
ports:
|
|
- "83:83"
|
|
networks:
|
|
- MIH_Network
|
|
depends_on:
|
|
- MIH_API_Hub
|
|
#============== API Hub ====================================================================
|
|
MIH_API_Hub:
|
|
build:
|
|
context: ./mih_api_hub
|
|
target: builder
|
|
container_name: MIH_API_Hub
|
|
ports:
|
|
- 8080:80
|
|
volumes:
|
|
- ./mih_api_hub:/app
|
|
networks:
|
|
- MIH_Network
|
|
depends_on:
|
|
- MIH_DB
|
|
#============== My SQL DB ====================================================================
|
|
MIH_DB:
|
|
platform: linux/amd64
|
|
image: mysql:5.7
|
|
container_name: MIH_DB
|
|
restart: always
|
|
environment:
|
|
MYSQL_ROOT_PASSWORD: ${SQL_ROOT_PW}
|
|
MYSQL_USER: ${SQL_USER}
|
|
MYSQL_PASSWORD: ${SQL_USER_PW}
|
|
MYSQL_DATABASE: ${SUPERTOKENS_DB}
|
|
networks:
|
|
- MIH_Network
|
|
ports:
|
|
- '3306:3306'
|
|
volumes:
|
|
- ./mih_db:/var/lib/mysql
|
|
#============== PHP My Admin ====================================================================
|
|
# phpmyadmin:
|
|
# platform: linux/amd64
|
|
# image: phpmyadmin/phpmyadmin
|
|
# container_name: MIH-phpmyadmin
|
|
# environment:
|
|
# PMA_HOST: MIH_DB
|
|
# PMA_PORT: 3306
|
|
# PMA_ARBITRARY:
|
|
# networks:
|
|
# - MIH_Network
|
|
# restart: always
|
|
# ports:
|
|
# - 8081:80
|
|
# depends_on:
|
|
# - MIH_DB
|
|
#============== Minio File Storage ====================================================================
|
|
MIH_Minio:
|
|
platform: linux/amd64
|
|
container_name: MIH_Minio
|
|
hostname: MIH_Minio
|
|
image: minio/minio
|
|
ports:
|
|
- '9000:9000'
|
|
- '9001:9001'
|
|
volumes:
|
|
- './mih_minio:/data'
|
|
environment:
|
|
MINIO_ROOT_USER: ${MINIO_ROOT_USER}
|
|
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PW}
|
|
networks:
|
|
- MIH_Network
|
|
command: ["server", "/data", "--console-address", ":9001"]
|
|
#============== MIH-Monitor Portainer ====================================================================
|
|
MIH_Monitor:
|
|
container_name: MIH_Monitor
|
|
image: portainer/portainer-ce:2.20.3
|
|
ports:
|
|
- 9444:9443
|
|
volumes:
|
|
- ./mih_monitor/data:/data
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
restart: unless-stopped
|
|
networks:
|
|
- MIH_Network
|
|
#============== MIH-AI Ollama ====================================================================
|
|
MIH_AI:
|
|
container_name: MIH_AI
|
|
image: ollama/ollama:latest
|
|
ports:
|
|
- 11434:11434
|
|
volumes:
|
|
- ./mih_ai/ollama/ollama:/root/.ollama
|
|
pull_policy: always
|
|
tty: true
|
|
restart: always
|
|
environment:
|
|
- OLLAMA_ORIGINS=*
|
|
- OLLAMA_KEEP_ALIVE=24h
|
|
- OLLAMA_HOST=0.0.0.0
|
|
networks:
|
|
- MIH_Network
|
|
# === Added section for NVIDIA GPU acceleration ===
|
|
# runtime: nvidia
|
|
# deploy:
|
|
# resources:
|
|
# reservations:
|
|
# devices:
|
|
# - driver: nvidia
|
|
# count: all # or specify a number of GPUs
|
|
# capabilities: [ gpu ]
|
|
#============== Firebaase ====================================================================
|
|
# firebase:
|
|
# container_name: MIH-firebase-emulator
|
|
# build:
|
|
# context: ./Firebase-emulator
|
|
# environment:
|
|
# DATA_DIRECTORY: "firebase/data"
|
|
# FIREBASE_PROJECT: "mzansi-innovation-hub"
|
|
# ports:
|
|
# - 8082:8080 # FIRESTORE_PORT
|
|
# - 5005:5005 # FIRESTORE_WS_PORT
|
|
# - 4000:4000 # UI_PORT
|
|
# - 9099:9099 # AUTH_PORT
|
|
# - 5000:6001 # Hosting
|
|
# volumes:
|
|
# - ./Firebase-emulator:/srv/firebase:rw
|
|
# # - ./cache:/root/.cache/:rw
|
|
# # - ~/.config/:/root/.config
|
|
# - ./Firebase-emulator/firebase/data:/srv/firebase/data:rw
|