Fix
This commit is contained in:
29
deploy/jta/.env.example
Normal file
29
deploy/jta/.env.example
Normal file
@@ -0,0 +1,29 @@
|
||||
POSTGRES_DB=hll_vietnam
|
||||
POSTGRES_USER=hll_vietnam
|
||||
POSTGRES_PASSWORD=change-me
|
||||
POSTGRES_PORT=5432
|
||||
|
||||
BACKEND_PORT=8000
|
||||
FRONTEND_PORT=8080
|
||||
FRONTEND_BACKEND_BASE_URL=http://127.0.0.1:8000
|
||||
HLL_BACKEND_ALLOWED_ORIGINS=http://127.0.0.1:8080,http://localhost:8080
|
||||
|
||||
HLL_BACKEND_DATABASE_URL=postgresql://hll_vietnam:change-me@postgres:5432/hll_vietnam
|
||||
HLL_BACKEND_LIVE_DATA_SOURCE=rcon
|
||||
HLL_BACKEND_HISTORICAL_DATA_SOURCE=rcon
|
||||
HLL_BACKEND_RCON_TARGETS='[{"name":"Comunidad Hispana #01","slug":"comunidad-hispana-01","external_server_id":"comunidad-hispana-01","host":"203.0.113.10","port":7779,"password":"replace-me-01","source_name":"community-hispana-rcon","region":"ES","game_port":7777,"query_port":7778}]'
|
||||
|
||||
HLL_DB_MAINTENANCE_ENABLED=false
|
||||
HLL_DB_MAINTENANCE_INTERVAL_SECONDS=43200
|
||||
HLL_RECENT_MATCHES_KEEP=100
|
||||
HLL_ADMIN_LOG_NONCRITICAL_RETENTION_DAYS=30
|
||||
HLL_ADMIN_LOG_CRITICAL_RETENTION_DAYS=90
|
||||
HLL_SERVER_SNAPSHOT_RETENTION_DAYS=14
|
||||
HLL_DB_MAINTENANCE_BATCH_SIZE=5000
|
||||
|
||||
HLL_BACKEND_RCON_HISTORICAL_INTERVAL_SECONDS=5
|
||||
HLL_RCON_CURRENT_MATCH_CAPTURE_INTERVAL_SECONDS=5
|
||||
HLL_RCON_HISTORICAL_CAPTURE_MAX_RETRIES=0
|
||||
HLL_RCON_HISTORICAL_CAPTURE_RETRY_DELAY_SECONDS=0
|
||||
HLL_RCON_CURRENT_MATCH_WRITER_LOCK_TIMEOUT_SECONDS=4
|
||||
HLL_BACKEND_RCON_ADMIN_LOG_LOOKBACK_MINUTES=10
|
||||
164
deploy/jta/README.md
Normal file
164
deploy/jta/README.md
Normal file
@@ -0,0 +1,164 @@
|
||||
# JTA Docker Compose Deploy
|
||||
|
||||
Este despliegue prepara una variante directa para JTA sin Portainer y sin tocar
|
||||
la logica funcional del proyecto.
|
||||
|
||||
## Archivos
|
||||
|
||||
- `docker-compose.yml`: stack directo para JTA
|
||||
- `.env.example`: plantilla de variables sin credenciales reales
|
||||
- `backups/`: carpeta local para dumps `.dump` o `.sql`
|
||||
|
||||
## Preparacion
|
||||
|
||||
1. Copia la plantilla:
|
||||
|
||||
```powershell
|
||||
Copy-Item deploy/jta/.env.example deploy/jta/.env
|
||||
```
|
||||
|
||||
2. Ajusta como minimo:
|
||||
|
||||
- `POSTGRES_PASSWORD`
|
||||
- `HLL_BACKEND_RCON_TARGETS`
|
||||
- `FRONTEND_BACKEND_BASE_URL`
|
||||
- `HLL_BACKEND_ALLOWED_ORIGINS`
|
||||
|
||||
Notas:
|
||||
|
||||
- `HLL_BACKEND_RCON_TARGETS` debe ser un JSON valido en una sola linea.
|
||||
- en `.env` conviene dejar ese JSON entre comillas simples para preservar los espacios
|
||||
- `HLL_DB_MAINTENANCE_ENABLED=false` queda desactivado por defecto.
|
||||
- `FRONTEND_BACKEND_BASE_URL` debe apuntar a la URL que vera el navegador.
|
||||
Ejemplo remoto: `http://IP_O_DOMINIO_JTA:8000`.
|
||||
- `HLL_BACKEND_ALLOWED_ORIGINS` debe incluir la URL publica del frontend.
|
||||
Ejemplo remoto: `http://IP_O_DOMINIO_JTA:8080`.
|
||||
|
||||
## Arranque
|
||||
|
||||
Desde la raiz del repo:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env up -d --build
|
||||
```
|
||||
|
||||
Alternativa equivalente desde `deploy/jta`:
|
||||
|
||||
```powershell
|
||||
cd deploy/jta
|
||||
docker compose --env-file .env up -d --build
|
||||
```
|
||||
|
||||
Ambas funcionan porque los contextos de build y los bind mounts se resuelven
|
||||
relativos a `deploy/jta/docker-compose.yml`.
|
||||
|
||||
## Arranque Con Workers Advanced
|
||||
|
||||
Desde raiz:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env --profile advanced up -d --build
|
||||
```
|
||||
|
||||
Desde `deploy/jta`:
|
||||
|
||||
```powershell
|
||||
docker compose --env-file .env --profile advanced up -d --build
|
||||
```
|
||||
|
||||
Servicios:
|
||||
|
||||
- normales: `postgres`, `backend`, `frontend`
|
||||
- perfil `advanced`: `historical-runner`, `rcon-historical-worker`
|
||||
|
||||
## Parada
|
||||
|
||||
Parada sin borrar datos:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env down
|
||||
```
|
||||
|
||||
Advertencia:
|
||||
|
||||
- no usar `docker compose down -v`
|
||||
- no borrar el volumen `jta-postgres-data`
|
||||
|
||||
## Backup Y Restore
|
||||
|
||||
Esta task no ejecuta backup ni restore real. Los comandos siguientes son solo
|
||||
runbook operativo.
|
||||
|
||||
### 1. Crear dump desde el PostgreSQL actual
|
||||
|
||||
Ejemplo usando el contenedor PostgreSQL actual:
|
||||
|
||||
```powershell
|
||||
docker exec -t hll-vietnam-postgres pg_dump -U hll_vietnam -d hll_vietnam -Fc -f /tmp/hll_vietnam_jta.dump
|
||||
docker cp hll-vietnam-postgres:/tmp/hll_vietnam_jta.dump .\hll_vietnam_jta.dump
|
||||
Copy-Item .\hll_vietnam_jta.dump deploy\jta\backups\
|
||||
```
|
||||
|
||||
Si el nombre del contenedor actual es distinto, sustituirlo por el real.
|
||||
|
||||
### 2. Levantar solo PostgreSQL en JTA
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env up -d postgres
|
||||
```
|
||||
|
||||
### 3. Restaurar dump en JTA
|
||||
|
||||
Con el dump ya copiado a `deploy/jta/backups/`:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env exec postgres sh -c "pg_restore --clean --if-exists -U \"$POSTGRES_USER\" -d \"$POSTGRES_DB\" /backups/hll_vietnam_jta.dump"
|
||||
```
|
||||
|
||||
## Validacion De Datos Tras Restore
|
||||
|
||||
Comprobar tablas clave:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env exec postgres sh -c "psql -U \"$POSTGRES_USER\" -d \"$POSTGRES_DB\" -c 'select count(*) from rcon_materialized_matches;'"
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env exec postgres sh -c "psql -U \"$POSTGRES_USER\" -d \"$POSTGRES_DB\" -c 'select count(*) from rcon_admin_log_events;'"
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env exec postgres sh -c "psql -U \"$POSTGRES_USER\" -d \"$POSTGRES_DB\" -c 'select count(*) from displayed_historical_snapshots;'"
|
||||
```
|
||||
|
||||
## Endpoints A Probar
|
||||
|
||||
- frontend: `http://IP_O_DOMINIO_JTA:8080`
|
||||
- backend health: `http://IP_O_DOMINIO_JTA:8000/health`
|
||||
- `http://IP_O_DOMINIO_JTA:8000/api/servers`
|
||||
- `http://IP_O_DOMINIO_JTA:8000/api/historical/server-summary?server=comunidad-hispana-01`
|
||||
- `http://IP_O_DOMINIO_JTA:8000/api/historical/recent-matches?limit=20&server=comunidad-hispana-01`
|
||||
|
||||
## Logs A Revisar
|
||||
|
||||
Basicos:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env logs --tail=200 postgres backend frontend
|
||||
```
|
||||
|
||||
Advanced:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env logs --tail=200 historical-runner rcon-historical-worker
|
||||
```
|
||||
|
||||
Eventos utiles a buscar:
|
||||
|
||||
- `database-maintenance-scheduler-*`
|
||||
- `historical-refresh-*`
|
||||
- `database-maintenance-*`
|
||||
- errores de conexion RCON
|
||||
|
||||
## Validacion Del Compose
|
||||
|
||||
La plantilla incluida usa valores de ejemplo sintacticamente validos, incluido
|
||||
el JSON de `HLL_BACKEND_RCON_TARGETS`, para permitir:
|
||||
|
||||
```powershell
|
||||
docker compose -f deploy/jta/docker-compose.yml --env-file deploy/jta/.env.example config
|
||||
```
|
||||
1
deploy/jta/backups/.gitkeep
Normal file
1
deploy/jta/backups/.gitkeep
Normal file
@@ -0,0 +1 @@
|
||||
|
||||
149
deploy/jta/docker-compose.yml
Normal file
149
deploy/jta/docker-compose.yml
Normal file
@@ -0,0 +1,149 @@
|
||||
services:
|
||||
postgres:
|
||||
image: postgres:16-alpine
|
||||
environment:
|
||||
POSTGRES_DB: ${POSTGRES_DB:-hll_vietnam}
|
||||
POSTGRES_USER: ${POSTGRES_USER:-hll_vietnam}
|
||||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-change-me}
|
||||
TZ: Europe/Madrid
|
||||
ports:
|
||||
- "${POSTGRES_PORT:-5432}:5432"
|
||||
volumes:
|
||||
- jta-postgres-data:/var/lib/postgresql/data
|
||||
- ./backups:/backups
|
||||
healthcheck:
|
||||
test:
|
||||
- CMD-SHELL
|
||||
- pg_isready -U "$$POSTGRES_USER" -d "$$POSTGRES_DB" -p 5432
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 12
|
||||
restart: unless-stopped
|
||||
|
||||
backend:
|
||||
image: hll-vietnam-backend:jta
|
||||
build:
|
||||
context: ../../backend
|
||||
dockerfile: Dockerfile
|
||||
environment: &backend_environment
|
||||
HLL_BACKEND_HOST: 0.0.0.0
|
||||
HLL_BACKEND_PORT: ${BACKEND_PORT:-8000}
|
||||
HLL_BACKEND_DATABASE_URL: ${HLL_BACKEND_DATABASE_URL:?HLL_BACKEND_DATABASE_URL is required}
|
||||
HLL_BACKEND_ALLOWED_ORIGINS: ${HLL_BACKEND_ALLOWED_ORIGINS:?HLL_BACKEND_ALLOWED_ORIGINS is required}
|
||||
HLL_BACKEND_LIVE_DATA_SOURCE: ${HLL_BACKEND_LIVE_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_HISTORICAL_DATA_SOURCE: ${HLL_BACKEND_HISTORICAL_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_RCON_TARGETS: ${HLL_BACKEND_RCON_TARGETS:?HLL_BACKEND_RCON_TARGETS is required}
|
||||
HLL_DB_MAINTENANCE_ENABLED: ${HLL_DB_MAINTENANCE_ENABLED:-false}
|
||||
HLL_DB_MAINTENANCE_INTERVAL_SECONDS: ${HLL_DB_MAINTENANCE_INTERVAL_SECONDS:-43200}
|
||||
HLL_RECENT_MATCHES_KEEP: ${HLL_RECENT_MATCHES_KEEP:-100}
|
||||
HLL_ADMIN_LOG_NONCRITICAL_RETENTION_DAYS: ${HLL_ADMIN_LOG_NONCRITICAL_RETENTION_DAYS:-30}
|
||||
HLL_ADMIN_LOG_CRITICAL_RETENTION_DAYS: ${HLL_ADMIN_LOG_CRITICAL_RETENTION_DAYS:-90}
|
||||
HLL_SERVER_SNAPSHOT_RETENTION_DAYS: ${HLL_SERVER_SNAPSHOT_RETENTION_DAYS:-14}
|
||||
HLL_DB_MAINTENANCE_BATCH_SIZE: ${HLL_DB_MAINTENANCE_BATCH_SIZE:-5000}
|
||||
ports:
|
||||
- "${BACKEND_PORT:-8000}:${BACKEND_PORT:-8000}"
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
volumes:
|
||||
- jta-backend-data:/app/data
|
||||
restart: unless-stopped
|
||||
|
||||
frontend:
|
||||
build:
|
||||
context: ../../frontend
|
||||
dockerfile: Dockerfile
|
||||
command:
|
||||
- sh
|
||||
- -c
|
||||
- |
|
||||
python - <<'PY'
|
||||
import os
|
||||
import re
|
||||
from pathlib import Path
|
||||
|
||||
base_url = os.environ.get("FRONTEND_BACKEND_BASE_URL", "http://127.0.0.1:8000")
|
||||
pattern = re.compile(r'data-backend-base-url="[^"]*"')
|
||||
replacement = f'data-backend-base-url="{base_url}"'
|
||||
|
||||
for path in Path("/srv/frontend").glob("*.html"):
|
||||
text = path.read_text(encoding="utf-8")
|
||||
text = pattern.sub(replacement, text)
|
||||
path.write_text(text, encoding="utf-8")
|
||||
PY
|
||||
python -m http.server "${FRONTEND_PORT:-8080}" --bind 0.0.0.0 --directory /srv/frontend
|
||||
environment:
|
||||
FRONTEND_PORT: ${FRONTEND_PORT:-8080}
|
||||
FRONTEND_BACKEND_BASE_URL: ${FRONTEND_BACKEND_BASE_URL:?FRONTEND_BACKEND_BASE_URL is required}
|
||||
ports:
|
||||
- "${FRONTEND_PORT:-8080}:${FRONTEND_PORT:-8080}"
|
||||
depends_on:
|
||||
backend:
|
||||
condition: service_started
|
||||
restart: unless-stopped
|
||||
|
||||
historical-runner:
|
||||
profiles:
|
||||
- advanced
|
||||
image: hll-vietnam-backend:jta
|
||||
build:
|
||||
context: ../../backend
|
||||
dockerfile: Dockerfile
|
||||
command:
|
||||
- python
|
||||
- -m
|
||||
- app.historical_runner
|
||||
- --hourly
|
||||
environment:
|
||||
<<: *backend_environment
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
backend:
|
||||
condition: service_started
|
||||
volumes:
|
||||
- jta-backend-data:/app/data
|
||||
restart: unless-stopped
|
||||
|
||||
rcon-historical-worker:
|
||||
profiles:
|
||||
- advanced
|
||||
image: hll-vietnam-backend:jta
|
||||
build:
|
||||
context: ../../backend
|
||||
dockerfile: Dockerfile
|
||||
command:
|
||||
- python
|
||||
- -m
|
||||
- app.rcon_historical_worker
|
||||
- loop
|
||||
- --capture-mode
|
||||
- current-live
|
||||
- --interval
|
||||
- "5"
|
||||
- --retries
|
||||
- "0"
|
||||
- --retry-delay
|
||||
- "0"
|
||||
environment:
|
||||
<<: *backend_environment
|
||||
HLL_RCON_HISTORICAL_CAPTURE_INTERVAL_SECONDS: ${HLL_BACKEND_RCON_HISTORICAL_INTERVAL_SECONDS:-5}
|
||||
HLL_RCON_CURRENT_MATCH_CAPTURE_INTERVAL_SECONDS: ${HLL_RCON_CURRENT_MATCH_CAPTURE_INTERVAL_SECONDS:-5}
|
||||
HLL_RCON_CURRENT_MATCH_MODE: "true"
|
||||
HLL_RCON_SKIP_HISTORICAL_MATERIALIZATION: "true"
|
||||
HLL_RCON_HISTORICAL_CAPTURE_MAX_RETRIES: ${HLL_RCON_HISTORICAL_CAPTURE_MAX_RETRIES:-0}
|
||||
HLL_RCON_HISTORICAL_CAPTURE_RETRY_DELAY_SECONDS: ${HLL_RCON_HISTORICAL_CAPTURE_RETRY_DELAY_SECONDS:-0}
|
||||
HLL_RCON_CURRENT_MATCH_WRITER_LOCK_TIMEOUT_SECONDS: ${HLL_RCON_CURRENT_MATCH_WRITER_LOCK_TIMEOUT_SECONDS:-4}
|
||||
HLL_BACKEND_RCON_ADMIN_LOG_LOOKBACK_MINUTES: ${HLL_BACKEND_RCON_ADMIN_LOG_LOOKBACK_MINUTES:-10}
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
backend:
|
||||
condition: service_started
|
||||
volumes:
|
||||
- jta-backend-data:/app/data
|
||||
restart: unless-stopped
|
||||
|
||||
volumes:
|
||||
jta-postgres-data:
|
||||
jta-backend-data:
|
||||
8
deploy/portainer/Caddyfile.example
Normal file
8
deploy/portainer/Caddyfile.example
Normal file
@@ -0,0 +1,8 @@
|
||||
comunidadhll.devzamode.es {
|
||||
encode zstd gzip
|
||||
|
||||
reverse_proxy /health hll-vietnam-backend-1:8000
|
||||
reverse_proxy /api/* hll-vietnam-backend-1:8000
|
||||
|
||||
reverse_proxy hll-vietnam-frontend-1:8080
|
||||
}
|
||||
128
deploy/portainer/docker-compose.nas.yml
Normal file
128
deploy/portainer/docker-compose.nas.yml
Normal file
@@ -0,0 +1,128 @@
|
||||
services:
|
||||
postgres:
|
||||
image: postgres:16-alpine
|
||||
environment:
|
||||
POSTGRES_DB: ${POSTGRES_DB:-hll_vietnam}
|
||||
POSTGRES_USER: ${POSTGRES_USER:-hll_vietnam}
|
||||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:?POSTGRES_PASSWORD is required}
|
||||
volumes:
|
||||
- postgres-data:/var/lib/postgresql/data
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 12
|
||||
networks:
|
||||
- hll-internal
|
||||
restart: unless-stopped
|
||||
|
||||
backend:
|
||||
build:
|
||||
context: ../../backend
|
||||
environment:
|
||||
HLL_BACKEND_DATABASE_URL: ${HLL_BACKEND_DATABASE_URL:?HLL_BACKEND_DATABASE_URL is required}
|
||||
HLL_BACKEND_HOST: ${HLL_BACKEND_HOST:-0.0.0.0}
|
||||
HLL_BACKEND_PORT: ${HLL_BACKEND_PORT:-8000}
|
||||
HLL_BACKEND_ALLOWED_ORIGINS: ${HLL_BACKEND_ALLOWED_ORIGINS:-https://comunidadhll.devzamode.es}
|
||||
HLL_BACKEND_LIVE_DATA_SOURCE: ${HLL_BACKEND_LIVE_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_HISTORICAL_DATA_SOURCE: ${HLL_BACKEND_HISTORICAL_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_RCON_TIMEOUT_SECONDS: ${HLL_BACKEND_RCON_TIMEOUT_SECONDS:-20}
|
||||
HLL_BACKEND_RCON_TARGETS: ${HLL_BACKEND_RCON_TARGETS:?HLL_BACKEND_RCON_TARGETS is required}
|
||||
expose:
|
||||
- "8000"
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
volumes:
|
||||
- backend-data:/app/data
|
||||
networks:
|
||||
- hll-internal
|
||||
- caddy
|
||||
restart: unless-stopped
|
||||
|
||||
frontend:
|
||||
build:
|
||||
context: ../../frontend
|
||||
command:
|
||||
- sh
|
||||
- -c
|
||||
- |
|
||||
python - <<'PY'
|
||||
from pathlib import Path
|
||||
for path in Path('/srv/frontend').glob('*.html'):
|
||||
text = path.read_text(encoding='utf-8')
|
||||
text = text.replace('data-backend-base-url="http://127.0.0.1:8000"', 'data-backend-base-url=""')
|
||||
path.write_text(text, encoding='utf-8')
|
||||
PY
|
||||
python -m http.server 8080 --bind 0.0.0.0 --directory /srv/frontend
|
||||
expose:
|
||||
- "8080"
|
||||
depends_on:
|
||||
- backend
|
||||
networks:
|
||||
- caddy
|
||||
restart: unless-stopped
|
||||
|
||||
historical-runner:
|
||||
profiles:
|
||||
- advanced
|
||||
build:
|
||||
context: ../../backend
|
||||
command: ["python", "-m", "app.historical_runner", "--hourly"]
|
||||
environment:
|
||||
HLL_BACKEND_DATABASE_URL: ${HLL_BACKEND_DATABASE_URL:?HLL_BACKEND_DATABASE_URL is required}
|
||||
HLL_BACKEND_LIVE_DATA_SOURCE: ${HLL_BACKEND_LIVE_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_HISTORICAL_DATA_SOURCE: ${HLL_BACKEND_HISTORICAL_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_RCON_TIMEOUT_SECONDS: ${HLL_BACKEND_RCON_TIMEOUT_SECONDS:-20}
|
||||
HLL_BACKEND_RCON_TARGETS: ${HLL_BACKEND_RCON_TARGETS:?HLL_BACKEND_RCON_TARGETS is required}
|
||||
HLL_HISTORICAL_REFRESH_INTERVAL_SECONDS: ${HLL_HISTORICAL_REFRESH_INTERVAL_SECONDS:-3600}
|
||||
HLL_HISTORICAL_REFRESH_MAX_RETRIES: ${HLL_HISTORICAL_REFRESH_MAX_RETRIES:-2}
|
||||
HLL_HISTORICAL_REFRESH_RETRY_DELAY_SECONDS: ${HLL_HISTORICAL_REFRESH_RETRY_DELAY_SECONDS:-15}
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
backend:
|
||||
condition: service_started
|
||||
volumes:
|
||||
- backend-data:/app/data
|
||||
networks:
|
||||
- hll-internal
|
||||
restart: unless-stopped
|
||||
|
||||
rcon-historical-worker:
|
||||
profiles:
|
||||
- advanced
|
||||
build:
|
||||
context: ../../backend
|
||||
command: ["python", "-m", "app.rcon_historical_worker", "loop"]
|
||||
environment:
|
||||
HLL_BACKEND_DATABASE_URL: ${HLL_BACKEND_DATABASE_URL:?HLL_BACKEND_DATABASE_URL is required}
|
||||
HLL_BACKEND_LIVE_DATA_SOURCE: ${HLL_BACKEND_LIVE_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_HISTORICAL_DATA_SOURCE: ${HLL_BACKEND_HISTORICAL_DATA_SOURCE:-rcon}
|
||||
HLL_BACKEND_RCON_TIMEOUT_SECONDS: ${HLL_BACKEND_RCON_TIMEOUT_SECONDS:-20}
|
||||
HLL_BACKEND_RCON_TARGETS: ${HLL_BACKEND_RCON_TARGETS:?HLL_BACKEND_RCON_TARGETS is required}
|
||||
HLL_RCON_HISTORICAL_CAPTURE_INTERVAL_SECONDS: ${HLL_RCON_HISTORICAL_CAPTURE_INTERVAL_SECONDS:-600}
|
||||
HLL_RCON_HISTORICAL_CAPTURE_MAX_RETRIES: ${HLL_RCON_HISTORICAL_CAPTURE_MAX_RETRIES:-2}
|
||||
HLL_RCON_HISTORICAL_CAPTURE_RETRY_DELAY_SECONDS: ${HLL_RCON_HISTORICAL_CAPTURE_RETRY_DELAY_SECONDS:-15}
|
||||
HLL_BACKEND_RCON_ADMIN_LOG_LOOKBACK_MINUTES: ${HLL_BACKEND_RCON_ADMIN_LOG_LOOKBACK_MINUTES:-10}
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
backend:
|
||||
condition: service_started
|
||||
volumes:
|
||||
- backend-data:/app/data
|
||||
networks:
|
||||
- hll-internal
|
||||
restart: unless-stopped
|
||||
|
||||
volumes:
|
||||
postgres-data:
|
||||
backend-data:
|
||||
|
||||
networks:
|
||||
hll-internal:
|
||||
driver: bridge
|
||||
caddy:
|
||||
external: true
|
||||
name: ${CADDY_NETWORK:-stack-caddy}
|
||||
29
deploy/portainer/stack.env.example
Normal file
29
deploy/portainer/stack.env.example
Normal file
@@ -0,0 +1,29 @@
|
||||
# Copy these values into Portainer Stack environment variables.
|
||||
# Do not commit real production secrets.
|
||||
|
||||
POSTGRES_DB=hll_vietnam
|
||||
POSTGRES_USER=hll_vietnam
|
||||
POSTGRES_PASSWORD=replace-with-strong-postgres-password
|
||||
|
||||
HLL_BACKEND_DATABASE_URL=postgresql://hll_vietnam:replace-with-strong-postgres-password@postgres:5432/hll_vietnam
|
||||
HLL_BACKEND_HOST=0.0.0.0
|
||||
HLL_BACKEND_PORT=8000
|
||||
HLL_BACKEND_ALLOWED_ORIGINS=https://comunidadhll.devzamode.es
|
||||
HLL_BACKEND_LIVE_DATA_SOURCE=rcon
|
||||
HLL_BACKEND_HISTORICAL_DATA_SOURCE=rcon
|
||||
HLL_BACKEND_RCON_TIMEOUT_SECONDS=20
|
||||
HLL_BACKEND_RCON_TARGETS=[{"name":"Comunidad Hispana #01","slug":"comunidad-hispana-01","external_server_id":"comunidad-hispana-01","host":"replace-me-01.example","port":7779,"password":"replace-me-01","source_name":"community-hispana-rcon","region":"ES","game_port":null,"query_port":null},{"name":"Comunidad Hispana #02","slug":"comunidad-hispana-02","external_server_id":"comunidad-hispana-02","host":"replace-me-02.example","port":7879,"password":"replace-me-02","source_name":"community-hispana-rcon","region":"ES","game_port":null,"query_port":null}]
|
||||
|
||||
CADDY_NETWORK=stack-caddy
|
||||
|
||||
# Advanced profile only. Leave disabled unless you intentionally start the profile.
|
||||
HLL_HISTORICAL_REFRESH_INTERVAL_SECONDS=3600
|
||||
HLL_HISTORICAL_REFRESH_MAX_RETRIES=2
|
||||
HLL_HISTORICAL_REFRESH_RETRY_DELAY_SECONDS=15
|
||||
HLL_RCON_HISTORICAL_CAPTURE_INTERVAL_SECONDS=600
|
||||
HLL_RCON_HISTORICAL_CAPTURE_MAX_RETRIES=2
|
||||
HLL_RCON_HISTORICAL_CAPTURE_RETRY_DELAY_SECONDS=15
|
||||
HLL_BACKEND_RCON_ADMIN_LOG_LOOKBACK_MINUTES=10
|
||||
HLL_RCON_BACKFILL_CHUNK_HOURS=6
|
||||
HLL_RCON_BACKFILL_SLEEP_SECONDS=1
|
||||
HLL_RCON_BACKFILL_MAX_DAYS_BACK=45
|
||||
Reference in New Issue
Block a user