Compare commits

..

6 Commits

Author SHA1 Message Date
Nico Haider 02fe193cb1 add plane 2026-05-21 22:00:05 +02:00
Nico Haider 9b6bf1fcd3 projektverwaltung -> neoWork 2026-05-21 00:54:14 +02:00
Nico Haider d9e6f40323 move gastro to neoServe (mono-repo) 2026-05-07 23:06:40 +02:00
Nico Haider e92739a299 vaultwarden: activate admin dashboard 2026-05-03 00:19:52 +02:00
Nico Haider 6a7fad7620 add mongodb 2026-05-03 00:19:28 +02:00
Nico Haider 14f16dccbd add websites 2026-05-03 00:18:48 +02:00
7 changed files with 224 additions and 86 deletions
+4 -4
View File
@@ -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
+5 -4
View File
@@ -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
-46
View File
@@ -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
-32
View File
@@ -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
+22
View File
@@ -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
+192
View File
@@ -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"
+1
View File
@@ -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