Update docker-compose to use pre-built registry images
All checks were successful
CI/CD Pipeline / test (push) Successful in 1m47s
CI/CD Pipeline / build-engine (push) Has been skipped
CI/CD Pipeline / build-ui (push) Has been skipped

- Use gitea.thefetagroup.com/bnair/cryptobot:latest for engine
- Use gitea.thefetagroup.com/bnair/cryptobot-ui:latest for dashboard
- Remove deprecated 'version' field
- Change default DATA_ROOT from /opt/trading/crypto to ./data/
- Add start_period to healthchecks
- Add service dependency conditions
This commit is contained in:
bnair123
2025-12-27 21:45:30 +04:00
parent 49ea34041e
commit 2f065df1e9

View File

@@ -1,7 +1,15 @@
version: "3.9"
# TradeFinder - Automated Crypto Trading System # TradeFinder - Automated Crypto Trading System
# Mount point: /opt/trading/crypto (configurable via DATA_ROOT) # Uses pre-built images from Gitea Container Registry
#
# Quick Start:
# docker compose up -d
#
# With optimizer/backtester:
# docker compose --profile optimizer up -d
# docker compose --profile backtest run --rm backtester
#
# Environment:
# Copy .env.example to .env and configure API keys
x-common: &common x-common: &common
restart: unless-stopped restart: unless-stopped
@@ -13,43 +21,38 @@ x-common: &common
max-size: "10m" max-size: "10m"
max-file: "3" max-file: "3"
x-engine-image: &engine-image
image: gitea.thefetagroup.com/bnair/cryptobot:latest
x-ui-image: &ui-image
image: gitea.thefetagroup.com/bnair/cryptobot-ui:latest
services: services:
# ==========================================================================
# CORE TRADING ENGINE
# ==========================================================================
engine: engine:
<<: *common <<: [*common, *engine-image]
build:
context: .
dockerfile: Dockerfile
target: engine
container_name: tf-engine container_name: tf-engine
env_file: env_file:
- .env - .env
environment: environment:
- PYTHONUNBUFFERED=1 - PYTHONUNBUFFERED=1
- DUCKDB_PATH=/data/engine/tradefinder.duckdb - DUCKDB_PATH=/data/engine/tradefinder.duckdb
- TRADING_MODE=${TRADING_MODE:-paper}
volumes: volumes:
- ${DATA_ROOT:-/opt/trading/crypto}/engine:/data/engine - ${DATA_ROOT:-./data}/engine:/data/engine
- ${DATA_ROOT:-/opt/trading/crypto}/shared:/data/shared - ${DATA_ROOT:-./data}/shared:/data/shared
depends_on: depends_on:
- redis redis:
condition: service_healthy
healthcheck: healthcheck:
test: ["CMD", "python", "-c", "import tradefinder; print('ok')"] test: ["CMD", "python", "-c", "import tradefinder; print('ok')"]
interval: 30s interval: 30s
timeout: 10s timeout: 10s
retries: 3 retries: 3
start_period: 10s
command: ["python", "-m", "tradefinder.core.main"] command: ["python", "-m", "tradefinder.core.main"]
# ==========================================================================
# STREAMLIT UI
# ==========================================================================
ui: ui:
<<: *common <<: [*common, *ui-image]
build:
context: .
dockerfile: Dockerfile
target: ui
container_name: tf-ui container_name: tf-ui
env_file: env_file:
- .env - .env
@@ -59,8 +62,8 @@ services:
ports: ports:
- "${STREAMLIT_PORT:-8501}:8501" - "${STREAMLIT_PORT:-8501}:8501"
volumes: volumes:
- ${DATA_ROOT:-/opt/trading/crypto}/engine:/data/engine:ro - ${DATA_ROOT:-./data}/engine:/data/engine:ro
- ${DATA_ROOT:-/opt/trading/crypto}/shared:/data/shared - ${DATA_ROOT:-./data}/shared:/data/shared
depends_on: depends_on:
- engine - engine
healthcheck: healthcheck:
@@ -68,40 +71,15 @@ services:
interval: 30s interval: 30s
timeout: 10s timeout: 10s
retries: 3 retries: 3
start_period: 15s
command: ["streamlit", "run", "src/tradefinder/ui/app.py", "--server.port=8501", "--server.address=0.0.0.0"] command: ["streamlit", "run", "src/tradefinder/ui/app.py", "--server.port=8501", "--server.address=0.0.0.0"]
# ==========================================================================
# OPTIMIZER (runs weekly via scheduler or manually)
# ==========================================================================
optimizer:
<<: *common
build:
context: .
dockerfile: Dockerfile
target: engine
container_name: tf-optimizer
env_file:
- .env
environment:
- PYTHONUNBUFFERED=1
- DUCKDB_PATH=/data/engine/tradefinder.duckdb
volumes:
- ${DATA_ROOT:-/opt/trading/crypto}/engine:/data/engine
- ${DATA_ROOT:-/opt/trading/crypto}/optimizer:/data/optimizer
- ${DATA_ROOT:-/opt/trading/crypto}/shared:/data/shared
profiles:
- optimizer # Only runs when explicitly started: docker compose --profile optimizer up optimizer
command: ["python", "-m", "tradefinder.core.optimize"]
# ==========================================================================
# REDIS (for real-time state, pub/sub, caching)
# ==========================================================================
redis: redis:
<<: *common <<: *common
image: redis:7-alpine image: redis:7-alpine
container_name: tf-redis container_name: tf-redis
volumes: volumes:
- ${DATA_ROOT:-/opt/trading/crypto}/redis:/data - ${DATA_ROOT:-./data}/redis:/data
healthcheck: healthcheck:
test: ["CMD", "redis-cli", "ping"] test: ["CMD", "redis-cli", "ping"]
interval: 10s interval: 10s
@@ -109,15 +87,27 @@ services:
retries: 3 retries: 3
command: ["redis-server", "--appendonly", "yes", "--maxmemory", "256mb", "--maxmemory-policy", "allkeys-lru"] command: ["redis-server", "--appendonly", "yes", "--maxmemory", "256mb", "--maxmemory-policy", "allkeys-lru"]
# ========================================================================== optimizer:
# BACKTESTER (runs on-demand) <<: [*common, *engine-image]
# ========================================================================== container_name: tf-optimizer
env_file:
- .env
environment:
- PYTHONUNBUFFERED=1
- DUCKDB_PATH=/data/engine/tradefinder.duckdb
volumes:
- ${DATA_ROOT:-./data}/engine:/data/engine
- ${DATA_ROOT:-./data}/optimizer:/data/optimizer
- ${DATA_ROOT:-./data}/shared:/data/shared
depends_on:
redis:
condition: service_healthy
profiles:
- optimizer
command: ["python", "-m", "tradefinder.core.optimize"]
backtester: backtester:
<<: *common <<: [*common, *engine-image]
build:
context: .
dockerfile: Dockerfile
target: engine
container_name: tf-backtester container_name: tf-backtester
env_file: env_file:
- .env - .env
@@ -125,11 +115,11 @@ services:
- PYTHONUNBUFFERED=1 - PYTHONUNBUFFERED=1
- DUCKDB_PATH=/data/engine/tradefinder.duckdb - DUCKDB_PATH=/data/engine/tradefinder.duckdb
volumes: volumes:
- ${DATA_ROOT:-/opt/trading/crypto}/engine:/data/engine - ${DATA_ROOT:-./data}/engine:/data/engine
- ${DATA_ROOT:-/opt/trading/crypto}/backtest:/data/backtest - ${DATA_ROOT:-./data}/backtest:/data/backtest
- ${DATA_ROOT:-/opt/trading/crypto}/shared:/data/shared - ${DATA_ROOT:-./data}/shared:/data/shared
profiles: profiles:
- backtest # Only runs when explicitly started - backtest
command: ["python", "-m", "tradefinder.core.backtest"] command: ["python", "-m", "tradefinder.core.backtest"]
networks: networks:
@@ -137,10 +127,9 @@ networks:
driver: bridge driver: bridge
name: tradefinder-network name: tradefinder-network
# Volume labels for clarity # Data Structure (default: ./data/)
# All data persisted under ${DATA_ROOT:-/opt/trading/crypto}/ # ├── engine/ # DuckDB database, order logs, positions
# ├── engine/ # DuckDB, order logs, positions # ├── optimizer/ # Optuna studies, best parameters
# ├── optimizer/ # Optuna studies, best params
# ├── backtest/ # Backtest results, reports # ├── backtest/ # Backtest results, reports
# ├── redis/ # Redis AOF persistence # ├── redis/ # Redis AOF persistence
# └── shared/ # Shared configs, FX rates cache # └── shared/ # Shared configs, FX rates cache