Compare commits
6 Commits
5b92228024
..
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 02fe193cb1 | |||
| 9b6bf1fcd3 | |||
| d9e6f40323 | |||
| e92739a299 | |||
| 6a7fad7620 | |||
| 14f16dccbd |
+4
-4
@@ -49,13 +49,13 @@ out/
|
|||||||
byhaider-homepage
|
byhaider-homepage
|
||||||
byhaider-homepage-old
|
byhaider-homepage-old
|
||||||
mailcow
|
mailcow
|
||||||
projektverwaltung/backend
|
|
||||||
projektverwaltung/frontend
|
|
||||||
wichteln/backend
|
wichteln/backend
|
||||||
wichteln/frontend
|
wichteln/frontend
|
||||||
gravcms/sportakrobatik-dobersberg
|
gravcms/sportakrobatik-dobersberg
|
||||||
gastro/backend
|
websites/laserscan-haider
|
||||||
gastro/frontend
|
websites/haider
|
||||||
|
neoServe
|
||||||
|
neoWork
|
||||||
|
|
||||||
beszel/beszel_data/
|
beszel/beszel_data/
|
||||||
owncast/data
|
owncast/data
|
||||||
@@ -2,10 +2,11 @@
|
|||||||
- /byhaider-homepage → git clone https://git.byhaider.dev/nico/byhaider-homepage.git
|
- /byhaider-homepage → git clone https://git.byhaider.dev/nico/byhaider-homepage.git
|
||||||
- /byhaider-homepage-old → git clone https://git.byhaider.dev/nico/byhaider-homepage-old.git
|
- /byhaider-homepage-old → git clone https://git.byhaider.dev/nico/byhaider-homepage-old.git
|
||||||
- /mailcow → git clone https://git.byhaider.dev/nico/mailcow.git
|
- /mailcow → git clone https://git.byhaider.dev/nico/mailcow.git
|
||||||
- /projektverwaltung
|
|
||||||
- /projektverwaltung/backend -> git clone https://git.byhaider.dev/Projektverwaltung/backend.git
|
|
||||||
- /projektverwaltung/frontend -> git clone https://git.byhaider.dev/Projektverwaltung/frontend.git
|
|
||||||
- /wichteln
|
- /wichteln
|
||||||
- /wichteln/backend -> git clone https://git.byhaider.dev/Wichteln/backend.git
|
- /wichteln/backend -> git clone https://git.byhaider.dev/Wichteln/backend.git
|
||||||
- /wichteln/frontend -> git clone https://git.byhaider.dev/Wichteln/frontend.git
|
- /wichteln/frontend -> git clone https://git.byhaider.dev/Wichteln/frontend.git
|
||||||
- /gravcms/sportakrobatik-dobersberg -> git clone https://git.byhaider.dev/gravcms/sportakrobatik-dobersberg.git
|
- /gravcms/sportakrobatik-dobersberg -> git clone https://git.byhaider.dev/gravcms/sportakrobatik-dobersberg.git
|
||||||
|
- /websites/laserscan-haider -> git clone git clone ssh://git@git.byhaider.dev:1103/Websites/laserscan-haider.git
|
||||||
|
- /websites/haider -> git clone git clone ssh://git@git.byhaider.dev:1103/Websites/haider.git
|
||||||
|
- /neoServe -> git clone ssh://git@git.byhaider.dev:1103/apps/neoServe.git
|
||||||
|
- /neoWork -> git clone ssh://git@git.byhaider.dev:1103/apps/neoWork.git
|
||||||
@@ -1,46 +0,0 @@
|
|||||||
services:
|
|
||||||
backend:
|
|
||||||
build:
|
|
||||||
context: ./backend
|
|
||||||
image: gastro-backend:latest
|
|
||||||
container_name: gastro-backend
|
|
||||||
restart: unless-stopped
|
|
||||||
environment:
|
|
||||||
DATABASE_URL: ${DATABASE_URL}
|
|
||||||
DATABASE_USER: ${DATABASE_USER}
|
|
||||||
DATABASE_PASSWORD: ${DATABASE_PASSWORD}
|
|
||||||
|
|
||||||
JWT_SECRET: ${JWT_SECRET}
|
|
||||||
labels:
|
|
||||||
- "traefik.enable=true"
|
|
||||||
- "traefik.docker.network=traefik-network"
|
|
||||||
- "traefik.http.routers.gastro-backend.rule=Host(`api-gastro.byhaider.dev`)"
|
|
||||||
- "traefik.http.routers.gastro-backend.entrypoints=websecure"
|
|
||||||
- "traefik.http.routers.gastro-backend.tls=true"
|
|
||||||
- "traefik.http.routers.gastro-backend.tls.certResolver=cloudflare"
|
|
||||||
- "traefik.http.services.gastro-backend.loadbalancer.server.port=8080"
|
|
||||||
networks:
|
|
||||||
- postgresql
|
|
||||||
- traefik-network
|
|
||||||
|
|
||||||
frontend:
|
|
||||||
build:
|
|
||||||
context: ./frontend
|
|
||||||
image: gastro-frontend:latest
|
|
||||||
container_name: gastro-frontend
|
|
||||||
restart: unless-stopped
|
|
||||||
labels:
|
|
||||||
- "traefik.enable=true"
|
|
||||||
- "traefik.http.routers.gastro-frontend.rule=Host(`gastro.byhaider.dev`)"
|
|
||||||
- "traefik.http.routers.gastro-frontend.entrypoints=websecure"
|
|
||||||
- "traefik.http.routers.gastro-frontend.tls=true"
|
|
||||||
- "traefik.http.routers.gastro-frontend.tls.certResolver=cloudflare"
|
|
||||||
- "traefik.http.services.gastro-frontend.loadbalancer.server.port=80"
|
|
||||||
networks:
|
|
||||||
- traefik-network
|
|
||||||
|
|
||||||
networks:
|
|
||||||
traefik-network:
|
|
||||||
external: true
|
|
||||||
postgresql:
|
|
||||||
external: true
|
|
||||||
@@ -1,32 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
set -e
|
|
||||||
|
|
||||||
echo "🚀 Starte Deployment für Projektverwaltung..."
|
|
||||||
|
|
||||||
cd ~/docker-setup/projektverwaltung
|
|
||||||
|
|
||||||
echo "📥 Pull latest changes for backend..."
|
|
||||||
cd backend
|
|
||||||
git pull origin main
|
|
||||||
|
|
||||||
echo "📥 Pull latest changes for frontend..."
|
|
||||||
cd ../frontend
|
|
||||||
git pull origin main
|
|
||||||
|
|
||||||
cd ..
|
|
||||||
|
|
||||||
echo "🛑 Stoppe alte Container..."
|
|
||||||
docker compose down
|
|
||||||
|
|
||||||
echo "📦 Baue Images neu..."
|
|
||||||
docker compose build
|
|
||||||
|
|
||||||
echo "⬆️ Starte Container..."
|
|
||||||
docker compose up -d
|
|
||||||
|
|
||||||
echo "🧹 Bereinige alte Images..."
|
|
||||||
docker image prune -f
|
|
||||||
|
|
||||||
echo "✅ Deployment abgeschlossen!"
|
|
||||||
docker compose ps
|
|
||||||
|
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
services:
|
||||||
|
mongodb:
|
||||||
|
image: mongo:7
|
||||||
|
container_name: mongodb
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- mongodb:/data/db
|
||||||
|
networks:
|
||||||
|
- mongodb
|
||||||
|
ports:
|
||||||
|
- "27017:27017"
|
||||||
|
environment:
|
||||||
|
- MONGO_INITDB_ROOT_USERNAME=${MONGO_ROOT_USER}
|
||||||
|
- MONGO_INITDB_ROOT_PASSWORD=${MONGO_ROOT_PASSWORD}
|
||||||
|
|
||||||
|
networks:
|
||||||
|
mongodb:
|
||||||
|
external: true
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
mongodb:
|
||||||
|
external: true
|
||||||
@@ -0,0 +1,192 @@
|
|||||||
|
version: "3.8"
|
||||||
|
|
||||||
|
# ============================================================
|
||||||
|
# Plane Community Edition – board.byhaider.dev
|
||||||
|
# Traefik + externer PostgreSQL + eigener Redis + MinIO + RabbitMQ
|
||||||
|
# ============================================================
|
||||||
|
|
||||||
|
networks:
|
||||||
|
traefik-network:
|
||||||
|
external: true
|
||||||
|
postgresql:
|
||||||
|
external: true
|
||||||
|
plane-internal:
|
||||||
|
driver: bridge
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
plane-redisdata:
|
||||||
|
plane-rabbitmq:
|
||||||
|
plane-minio:
|
||||||
|
|
||||||
|
services:
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# Redis
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-redis:
|
||||||
|
image: valkey/valkey:7.2.11-alpine
|
||||||
|
container_name: plane-redis
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- plane-redisdata:/data
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "redis-cli", "ping"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# RabbitMQ
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-mq:
|
||||||
|
image: rabbitmq:3.13.6-management-alpine
|
||||||
|
container_name: plane-mq
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
RABBITMQ_DEFAULT_USER: ${RABBITMQ_USER}
|
||||||
|
RABBITMQ_DEFAULT_PASS: ${RABBITMQ_PASSWORD}
|
||||||
|
RABBITMQ_DEFAULT_VHOST: ${RABBITMQ_VHOST}
|
||||||
|
volumes:
|
||||||
|
- plane-rabbitmq:/var/lib/rabbitmq
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "rabbitmq-diagnostics", "ping"]
|
||||||
|
interval: 15s
|
||||||
|
timeout: 10s
|
||||||
|
retries: 5
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# MinIO
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-minio:
|
||||||
|
image: minio/minio
|
||||||
|
container_name: plane-minio
|
||||||
|
restart: unless-stopped
|
||||||
|
command: server /export --console-address ":9090"
|
||||||
|
environment:
|
||||||
|
MINIO_ROOT_USER: ${AWS_ACCESS_KEY_ID}
|
||||||
|
MINIO_ROOT_PASSWORD: ${AWS_SECRET_ACCESS_KEY}
|
||||||
|
volumes:
|
||||||
|
- plane-minio:/export
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
- traefik-network
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.docker.network=traefik-network"
|
||||||
|
- "traefik.http.routers.plane-minio.rule=Host(`board.byhaider.dev`) && PathPrefix(`/uploads`)"
|
||||||
|
- "traefik.http.routers.plane-minio.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.plane-minio.tls=true"
|
||||||
|
- "traefik.http.routers.plane-minio.tls.certresolver=cloudflare"
|
||||||
|
- "traefik.http.routers.plane-minio.priority=25"
|
||||||
|
- "traefik.http.services.plane-minio.loadbalancer.server.port=9000"
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# DB Migrator (einmalig beim Start)
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-migrator:
|
||||||
|
image: makeplane/plane-backend:stable
|
||||||
|
container_name: plane-migrator
|
||||||
|
restart: "no"
|
||||||
|
command: ./bin/docker-entrypoint-migrator.sh
|
||||||
|
env_file: .env
|
||||||
|
depends_on:
|
||||||
|
plane-redis:
|
||||||
|
condition: service_healthy
|
||||||
|
plane-mq:
|
||||||
|
condition: service_healthy
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
- postgresql
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# API Backend
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-api:
|
||||||
|
image: makeplane/plane-backend:stable
|
||||||
|
container_name: plane-api
|
||||||
|
restart: unless-stopped
|
||||||
|
command: ./bin/docker-entrypoint-api.sh
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
GUNICORN_WORKERS: "2"
|
||||||
|
depends_on:
|
||||||
|
plane-redis:
|
||||||
|
condition: service_healthy
|
||||||
|
plane-mq:
|
||||||
|
condition: service_healthy
|
||||||
|
plane-migrator:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
- postgresql
|
||||||
|
- traefik-network
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.docker.network=traefik-network"
|
||||||
|
- "traefik.http.routers.plane-api.rule=Host(`board.byhaider.dev`) && (PathPrefix(`/api`) || PathPrefix(`/auth`) || PathPrefix(`/static`))"
|
||||||
|
- "traefik.http.routers.plane-api.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.plane-api.tls=true"
|
||||||
|
- "traefik.http.routers.plane-api.tls.certresolver=cloudflare"
|
||||||
|
- "traefik.http.routers.plane-api.priority=20"
|
||||||
|
- "traefik.http.services.plane-api.loadbalancer.server.port=8000"
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# Background Worker
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-worker:
|
||||||
|
image: makeplane/plane-backend:stable
|
||||||
|
container_name: plane-worker
|
||||||
|
restart: unless-stopped
|
||||||
|
command: ./bin/docker-entrypoint-worker.sh
|
||||||
|
env_file: .env
|
||||||
|
depends_on:
|
||||||
|
- plane-api
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
- postgresql
|
||||||
|
extra_hosts:
|
||||||
|
- "mail.byhaider.dev:212.132.119.248"
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# Beat Scheduler
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-beat:
|
||||||
|
image: makeplane/plane-backend:stable
|
||||||
|
container_name: plane-beat
|
||||||
|
restart: unless-stopped
|
||||||
|
command: ./bin/docker-entrypoint-beat.sh
|
||||||
|
env_file: .env
|
||||||
|
depends_on:
|
||||||
|
- plane-api
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
- postgresql
|
||||||
|
extra_hosts:
|
||||||
|
- "mail.byhaider.dev:212.132.119.248"
|
||||||
|
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
# Frontend → Traefik
|
||||||
|
# ----------------------------------------------------------
|
||||||
|
plane-web:
|
||||||
|
image: makeplane/plane-frontend:stable
|
||||||
|
container_name: plane-web
|
||||||
|
restart: unless-stopped
|
||||||
|
env_file: .env
|
||||||
|
depends_on:
|
||||||
|
- plane-api
|
||||||
|
networks:
|
||||||
|
- plane-internal
|
||||||
|
- traefik-network
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.docker.network=traefik-network"
|
||||||
|
- "traefik.http.routers.plane-web.rule=Host(`board.byhaider.dev`)"
|
||||||
|
- "traefik.http.routers.plane-web.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.plane-web.tls=true"
|
||||||
|
- "traefik.http.routers.plane-web.tls.certresolver=cloudflare"
|
||||||
|
- "traefik.http.routers.plane-web.priority=10"
|
||||||
|
- "traefik.http.services.plane-web.loadbalancer.server.port=3000"
|
||||||
@@ -7,6 +7,7 @@ services:
|
|||||||
environment:
|
environment:
|
||||||
DOMAIN: "https://vault.byhaider.dev"
|
DOMAIN: "https://vault.byhaider.dev"
|
||||||
SIGNUPS_ALLOWED: "false"
|
SIGNUPS_ALLOWED: "false"
|
||||||
|
ADMIN_TOKEN: ${ADMIN_TOKEN}
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
- vaultwarden-data:/data
|
- vaultwarden-data:/data
|
||||||
|
|||||||
Reference in New Issue
Block a user