Refactor traefik and dozzle service configurations in docker-compose.yml

This commit is contained in:
2024-05-29 14:21:59 +08:00
parent dc55872b5d
commit 9b1fafa848
2 changed files with 69 additions and 76 deletions
+68 -4
View File
@@ -7,7 +7,6 @@ volumes:
services: services:
api_server: api_server:
image: furyhawk/listen:latest image: furyhawk/listen:latest
container_name: api_server
restart: always restart: always
depends_on: depends_on:
- postgres - postgres
@@ -20,14 +19,22 @@ services:
SECURITY__JWT_SECRET_KEY: ${SECURITY__JWT_SECRET_KEY} SECURITY__JWT_SECRET_KEY: ${SECURITY__JWT_SECRET_KEY}
SECURITY__BACKEND_CORS_ORIGINS: ${SECURITY__BACKEND_CORS_ORIGINS} SECURITY__BACKEND_CORS_ORIGINS: ${SECURITY__BACKEND_CORS_ORIGINS}
SECURITY__ALLOWED_HOSTS: ${SECURITY__ALLOWED_HOSTS} SECURITY__ALLOWED_HOSTS: ${SECURITY__ALLOWED_HOSTS}
DOMAINNAME: ${DOMAINNAME}
ports: ports:
- "8000:8000" - "8000:8000"
networks: networks:
- net - net
labels:
- "traefik.enable=true"
- "traefik.http.routers.api_server.entrypoints=web-secure"
- "traefik.http.routers.api_server.rule=Host(`api.${DOMAINNAME}`)"
- "traefik.http.routers.api_server.middlewares=auth@file, csrf@file, rate-limit@file"
- "traefik.http.routers.api_server.tls.certresolver=letsencrypt"
- "traefik.http.routers.api_server.service=api_server_service"
- "traefik.http.services.api_server_service.loadbalancer.server.port=8000"
postgres: postgres:
image: postgres image: postgres
container_name: postgres
environment: environment:
POSTGRES_DB: ${POSTGRES_DB} POSTGRES_DB: ${POSTGRES_DB}
POSTGRES_USER: ${POSTGRES_USER} POSTGRES_USER: ${POSTGRES_USER}
@@ -35,6 +42,7 @@ services:
PGDATA: "/var/lib/postgresql/data" PGDATA: "/var/lib/postgresql/data"
LANG: en_US.utf8 LANG: en_US.utf8
TZ: Asia/Singapore TZ: Asia/Singapore
DOMAINNAME: ${DOMAINNAME}
command: ["postgres", "-c", "log_connections=on"] command: ["postgres", "-c", "log_connections=on"]
volumes: volumes:
- postgres_data:/var/lib/postgresql/data - postgres_data:/var/lib/postgresql/data
@@ -48,6 +56,14 @@ services:
- "5432:5432" - "5432:5432"
networks: networks:
- net - net
labels:
- "traefik.enable=true"
- "traefik.http.routers.postgres.entrypoints=web-secure"
- "traefik.http.routers.postgres.rule=Host(`db.${DOMAINNAME}`)"
- "traefik.http.routers.postgres.middlewares=rate-limit@file, csrf@file"
- "traefik.http.routers.postgres.tls.certresolver=letsencrypt"
- "traefik.http.routers.postgres.service=postgres_service"
- "traefik.http.services.postgres_service.loadbalancer.server.port=5432"
osrm-backend: osrm-backend:
environment: environment:
@@ -60,22 +76,30 @@ services:
- OSRM_GEOFABRIK_PATH=${OSRM_GEOFABRIK_PATH} - OSRM_GEOFABRIK_PATH=${OSRM_GEOFABRIK_PATH}
# Notify OSRM Manager to restart without stopping container # Notify OSRM Manager to restart without stopping container
- OSRM_NOTIFY_FILEPATH=/data/osrm_notify.txt - OSRM_NOTIFY_FILEPATH=/data/osrm_notify.txt
- DOMAINNAME=${DOMAINNAME}
image: furyhawk/osrm-backend:${OSRM_VERSION:-latest} image: furyhawk/osrm-backend:${OSRM_VERSION:-latest}
container_name: osrm_backend
restart: unless-stopped restart: unless-stopped
expose: expose:
- ${OSRM_PORT:-5000} - ${OSRM_PORT:-5000}
networks: networks:
- net - net
labels:
- "traefik.enable=true"
- "traefik.http.routers.osrm-backend.entrypoints=web-secure"
- "traefik.http.routers.osrm-backend.rule=Host(`osrm.${DOMAINNAME}`)"
- "traefik.http.routers.osrm-backend.middlewares=csrf@file"
- "traefik.http.routers.osrm-backend.tls.certresolver=letsencrypt"
- "traefik.http.routers.osrm-backend.service=osrm_backend_service"
- "traefik.http.services.osrm_backend_service.loadbalancer.server.port=${OSRM_PORT:-5000}"
minio-common: minio-common:
image: minio/minio:latest image: minio/minio:latest
container_name: minio_server
environment: environment:
MINIO_ROOT_USER: "${MINIO_ROOT_USER:-minioadmin}" MINIO_ROOT_USER: "${MINIO_ROOT_USER:-minioadmin}"
MINIO_ROOT_PASSWORD: "${MINIO_ROOT_PASSWORD:-minioadmin}" MINIO_ROOT_PASSWORD: "${MINIO_ROOT_PASSWORD:-minioadmin}"
MINIO_OPTS: "--console-address :9001" MINIO_OPTS: "--console-address :9001"
MINIO_SERVER_URL: https://drive.furyhawk.lol MINIO_SERVER_URL: https://drive.furyhawk.lol
DOMAINNAME: ${DOMAINNAME}
# user: "1000:1000" # user: "1000:1000"
restart: unless-stopped restart: unless-stopped
command: server /data --address :9000 --console-address :9001 command: server /data --address :9000 --console-address :9001
@@ -91,6 +115,20 @@ services:
- 9001 - 9001
networks: networks:
- net - net
labels:
- "traefik.enable=true"
- "traefik.http.routers.minio-router.entrypoints=web-secure"
- "traefik.http.routers.minio-router.rule=Host(`drive.${DOMAINNAME}`) || Host(`storage.${DOMAINNAME}`)"
- "traefik.http.routers.minio-router.middlewares=auth@file, csrf@file"
- "traefik.http.routers.minio-router.tls.certresolver=letsencrypt"
- "traefik.http.routers.minio-router.service=minio_common_service"
- "traefik.http.services.minio_common_service.loadbalancer.server.port=9001"
- "traefik.http.routers.minio-api-router.entrypoints=web-secure"
- "traefik.http.routers.minio-api-router.rule=Host(`minio.${DOMAINNAME}`) || Host(`s3.${DOMAINNAME}`)"
- "traefik.http.routers.minio-api-router.middlewares=csrf@file"
- "traefik.http.routers.minio-api-router.tls.certresolver=letsencrypt"
- "traefik.http.routers.minio-api-router.service=minio_api_service"
- "traefik.http.services.minio_api_service.loadbalancer.server.port=9000"
neo4j_server: neo4j_server:
# Docker image to be used # Docker image to be used
@@ -126,6 +164,7 @@ services:
environment: environment:
- PUID=1000 - PUID=1000
- PGID=1000 - PGID=1000
- DOMAINNAME=${DOMAINNAME}
restart: unless-stopped restart: unless-stopped
volumes: volumes:
- ~/st-sync:/var/syncthing - ~/st-sync:/var/syncthing
@@ -136,6 +175,14 @@ services:
- "21027:21027/udp" # Receive local discovery broadcasts - "21027:21027/udp" # Receive local discovery broadcasts
networks: networks:
- net - net
labels:
- "traefik.enable=true"
- "traefik.http.routers.syncthing.entrypoints=web-secure"
- "traefik.http.routers.syncthing.rule=Host(`sync.${DOMAINNAME}`)"
- "traefik.http.routers.syncthing.middlewares=csrf@file"
- "traefik.http.routers.syncthing.tls.certresolver=letsencrypt"
- "traefik.http.routers.syncthing.service=syncthing_service"
- "traefik.http.services.syncthing_service.loadbalancer.server.port=8384"
dozzle: dozzle:
image: amir20/dozzle:latest image: amir20/dozzle:latest
@@ -157,6 +204,23 @@ services:
- "traefik.http.routers.dozzle.service=dozzle_service" - "traefik.http.routers.dozzle.service=dozzle_service"
- "traefik.http.services.dozzle_service.loadbalancer.server.port=8080" - "traefik.http.services.dozzle_service.loadbalancer.server.port=8080"
# WhoAmI - For Testing and Troubleshooting
whoami:
image: traefik/whoami
container_name: whoami
security_opt:
- no-new-privileges:true
restart: unless-stopped
networks:
- net
labels:
- "traefik.enable=true"
- "traefik.http.routers.whoami-rtr.entrypoints=web-secure"
- "traefik.http.routers.whoami-rtr.rule=Host(`whoami.$DOMAINNAME`)"
- "traefik.http.routers.whoami-rtr.middlewares=csrf@file"
- "traefik.http.routers.whoami-rtr.service=whoami-svc"
- "traefik.http.services.whoami-svc.loadbalancer.server.port=80"
# kestra: # kestra:
# image: kestra/kestra:latest-full # image: kestra/kestra:latest-full
# container_name: kestra # container_name: kestra
+1 -72
View File
@@ -36,9 +36,6 @@ entryPoints:
bolt-socket: bolt-socket:
address: ":7687" address: ":7687"
# osrm:
# address: ":5000"
certificatesResolvers: certificatesResolvers:
letsencrypt: letsencrypt:
# https://docs.traefik.io/master/https/acme/#lets-encrypt # https://docs.traefik.io/master/https/acme/#lets-encrypt
@@ -103,17 +100,6 @@ http:
certResolver: letsencrypt certResolver: letsencrypt
service: adminer_app service: adminer_app
api-router:
entryPoints:
- web-secure
rule: "Host(`api.furyhawk.lol`)"
middlewares:
- auth
- csrf
tls:
certResolver: letsencrypt
service: api_server
chat-router: chat-router:
entryPoints: entryPoints:
- web-secure - web-secure
@@ -236,26 +222,6 @@ http:
certResolver: letsencrypt certResolver: letsencrypt
service: thelounge_app service: thelounge_app
minio-router:
entryPoints:
- web-secure
rule: "Host(`drive.furyhawk.lol`) || Host(`storage.furyhawk.lol`)"
middlewares:
- csrf
tls:
certResolver: letsencrypt
service: minio_server
minio-api-router:
entryPoints:
- web-secure
rule: "Host(`minio.furyhawk.lol`) || Host(`s3.furyhawk.lol`)"
middlewares:
- csrf
tls:
certResolver: letsencrypt
service: minio_service
neo4j-router: neo4j-router:
entryPoints: entryPoints:
- web-secure - web-secure
@@ -321,27 +287,6 @@ http:
certResolver: letsencrypt certResolver: letsencrypt
service: mqttx-web service: mqttx-web
osrm-router:
entryPoints:
- "web-secure"
rule: "Host(`osrm.furyhawk.lol`)"
# - "osrm"
middlewares:
- csrf
tls:
certResolver: letsencrypt
service: osrm_service
syncthing-router:
entryPoints:
- web-secure
rule: "Host(`sync.furyhawk.lol`)"
middlewares:
- csrf
tls:
certResolver: letsencrypt
service: syncthing_app
bai-router: bai-router:
entryPoints: entryPoints:
- web-secure - web-secure
@@ -420,7 +365,7 @@ http:
rate-limit: rate-limit:
rateLimit: rateLimit:
average: 384 average: 384
burst: 64 burst: 128
period: 10s period: 10s
# redirect to resume # redirect to resume
@@ -466,10 +411,6 @@ http:
services: services:
osrm_service:
loadBalancer:
servers:
- url: http://osrm_backend:5000
adminer_app: adminer_app:
loadBalancer: loadBalancer:
servers: servers:
@@ -522,14 +463,6 @@ http:
loadBalancer: loadBalancer:
servers: servers:
- url: http://meshtastic_web:8080 - url: http://meshtastic_web:8080
minio_server:
loadBalancer:
servers:
- url: http://minio_server:9001
minio_service:
loadBalancer:
servers:
- url: http://minio_server:9000
neo4j-browser: neo4j-browser:
loadBalancer: loadBalancer:
servers: servers:
@@ -572,10 +505,6 @@ http:
loadBalancer: loadBalancer:
servers: servers:
- url: http://mqttx_web:80 - url: http://mqttx_web:80
syncthing_app:
loadBalancer:
servers:
- url: http://syncthing:8384
site_server: site_server:
loadBalancer: loadBalancer:
servers: servers: