mirror of
https://github.com/furyhawk/cloudy.git
synced 2026-05-24 00:45:58 +00:00
Refactor traefik and dozzle service configurations in docker-compose.yml
This commit is contained in:
+68
-4
@@ -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
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
Reference in New Issue
Block a user