Files
wallabicher/docker-compose.yml
Omar Sánchez Pizarro c3ef3daf5e Refactor worker management and enhance configuration options
- Updated docker-compose.yml to allow read-write access for workers.json.
- Introduced WorkerManager class in wallamonitor.py to manage workers dynamically based on workers.json configuration.
- Enhanced Worker class to support controlled start/stop operations and updated general arguments.
- Improved Workers.vue to include a general configuration modal and refined UI for active and disabled workers.
- Added functionality for global filters and improved worker editing capabilities.
- Implemented methods for saving general configuration and deleting workers.
2026-01-19 21:00:59 +01:00

105 lines
2.5 KiB
YAML

version: '3.8'
services:
# Redis para cache de artículos
redis:
image: redis:7-alpine
container_name: wallamonitor-redis
ports:
- "6379:6379"
volumes:
- redis-data:/data
command: redis-server --appendonly yes
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 3s
retries: 3
networks:
- wallamonitor-network
restart: unless-stopped
# Backend Node.js API
backend:
build:
context: ./web/backend
dockerfile: Dockerfile
container_name: wallamonitor-backend
ports:
- "3001:3001"
environment:
- NODE_ENV=production
- PORT=3001
- PROJECT_ROOT=/data
- REDIS_HOST=redis
volumes:
# Montar archivos de configuración y datos en ubicación predecible
- ./config.yaml:/data/config.yaml:ro
- ./workers.json:/data/workers.json:rw
- ./logs:/data/logs:rw
# Montar el directorio raíz para acceso a archivos
- .:/data/project:ro
depends_on:
redis:
condition: service_healthy
networks:
- wallamonitor-network
restart: unless-stopped
healthcheck:
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "http://localhost:3001/api/stats"]
interval: 30s
timeout: 10s
retries: 3
# Frontend Vue
frontend:
build:
context: ./web/frontend
dockerfile: Dockerfile
container_name: wallamonitor-frontend
ports:
- "3000:80"
depends_on:
- backend
networks:
- wallamonitor-network
restart: unless-stopped
# Servicio Python principal (Wallamonitor)
# NOTA: Para usar Redis, asegúrate de que config.yaml tenga:
# cache:
# type: "redis"
# redis:
# host: "redis" # Nombre del servicio en Docker
wallamonitor:
build:
context: .
dockerfile: Dockerfile
container_name: wallamonitor-python
environment:
- PYTHONUNBUFFERED=1
volumes:
# Montar archivos de configuración
- ./config.yaml:/app/config.yaml:ro
- ./workers.json:/app/workers.json:rw
# Montar directorio de logs en lugar del archivo para evitar problemas
- ./logs:/app/logs:rw
depends_on:
redis:
condition: service_healthy
backend:
condition: service_healthy
networks:
- wallamonitor-network
restart: unless-stopped
# El servicio Python no necesita exponer puertos, solo se comunica con Redis y Telegram
volumes:
redis-data:
driver: local
networks:
wallamonitor-network:
driver: bridge