added new docker compose file

This commit is contained in:
Dejan R. 2025-11-30 12:24:14 +00:00
parent 5235b4c681
commit 31a78678a1

View file

@ -1,23 +1,20 @@
version: "3.8"
services: services:
db: db:
image: mariadb:10.11 image: mariadb:10.11
restart: unless-stopped restart: unless-stopped
environment: environment:
# --- REPLACE THESE SECRETS --- # --- REPLACE THESE NOW ---
MYSQL_ROOT_PASSWORD: your_very_strong_root_password MYSQL_ROOT_PASSWORD: SuperSecretRoot123!
MYSQL_DATABASE: filerun MYSQL_DATABASE: filerun
MYSQL_USER: filerun MYSQL_USER: filerun
MYSQL_PASSWORD: your_very_strong_filerun_password MYSQL_PASSWORD: SuperSecretFileRun456!
# ---------------------------- # ------------------------
volumes: volumes:
- ./db_data:/var/lib/mysql - ./db_data:/var/lib/mysql
networks: networks:
- internal - internal
filerun: ffilerun:
# Assuming this is the correct image for your architecture.
image: filerun/filerun:8.1.arm64v8 image: filerun/filerun:8.1.arm64v8
restart: unless-stopped restart: unless-stopped
environment: environment:
@ -25,42 +22,33 @@ services:
FR_DB_PORT: 3306 FR_DB_PORT: 3306
FR_DB_NAME: filerun FR_DB_NAME: filerun
FR_DB_USER: filerun FR_DB_USER: filerun
# --- REPLACE THIS SECRET --- FR_DB_PASS: SuperSecretFileRun456!
FR_DB_PASS: your_very_strong_filerun_password
# --------------------------
APACHE_RUN_USER: www-data APACHE_RUN_USER: www-data
APACHE_RUN_GROUP: www-data APACHE_RUN_GROUP: www-data
volumes: volumes:
- ./filerun_html:/var/www/html - ./filerun_html:/var/www/html
- ./user_data:/user-files - ./user_data:/user-files
expose:
- "80" # TO MORA BITI TUKAJ!
networks: networks:
- internal - internal
- traefik_default # Connect to your existing Traefik network - traefik_default
depends_on: depends_on:
- db - db
labels: labels:
- "traefik.enable=true" - "traefik.enable=true"
# --- CRITICAL: FILE-RUN HTTPS MIDDLEWARE ---
# This middleware is vital for FileRun to correctly detect HTTPS when behind Traefik.
- "traefik.http.middlewares.filerun-headers.headers.customresponseheaders.X-Forwarded-Proto=https" - "traefik.http.middlewares.filerun-headers.headers.customresponseheaders.X-Forwarded-Proto=https"
# --- HTTP (Port 80) Router: Redirect to HTTPS ---
- "traefik.http.routers.filerun-http.entrypoints=web" - "traefik.http.routers.filerun-http.entrypoints=web"
- "traefik.http.routers.filerun-http.rule=Host(`filerun.rozic-dev.com`)" - "traefik.http.routers.filerun-http.rule=Host(`filerun.rozic-dev.com`)"
- "traefik.http.routers.filerun-http.middlewares=redirect-to-https@docker" # Assumes a global Traefik redirect middleware - "traefik.http.routers.filerun-http.middlewares=redirectscheme"
- "traefik.http.middlewares.redirectscheme.redirectscheme.scheme=https"
# --- HTTPS (Port 443) Router ---
- "traefik.http.routers.filerun-https.entrypoints=websecure" - "traefik.http.routers.filerun-https.entrypoints=websecure"
- "traefik.http.routers.filerun-https.rule=Host(`filerun.rozic-dev.com`)" - "traefik.http.routers.filerun-https.rule=Host(`filerun.rozic-dev.com`)"
- "traefik.http.routers.filerun-https.tls=true" - "traefik.http.routers.filerun-https.tls=true"
- "traefik.http.routers.filerun-https.tls.certresolver=letsencrypt" - "traefik.http.routers.filerun-https.tls.certresolver=letsencrypt"
- "traefik.http.routers.filerun-https.middlewares=filerun-headers@docker" # Apply the X-Forwarded-Proto header - "traefik.http.routers.filerun-https.middlewares=filerun-headers"
- "traefik.http.routers.filerun-https.priority=100" # Optional: higher priority - "traefik.http.routers.filerun-https.priority=100"
# --- Service Definition ---
- "traefik.http.services.filerun.loadbalancer.server.port=80" - "traefik.http.services.filerun.loadbalancer.server.port=80"
# IMPORTANT: Since Traefik is handling traffic, DO NOT include a 'ports' section here.
networks: networks:
internal: internal: