Files
openmonetis/docker-compose.prod.yml
Felipe Coutinho 4358bcfb10 feat: adição de workflows e documentação para publicação no Docker Hub
- Implementado o workflow GitHub Actions para build e push da imagem do OpenSheets para o Docker Hub.
- Criado guia de deploy no Coolify, detalhando opções de uso e configuração.
- Atualizados arquivos de configuração do Docker Compose para produção, incluindo serviços e variáveis de ambiente.
- Adicionadas instruções para gerenciamento de versões e troubleshooting.
2025-11-15 16:37:27 -03:00

132 lines
3.4 KiB
YAML

# Docker Compose para Produção (com imagem do Docker Hub)
# Uso: docker compose -f docker-compose.prod.yml up -d
name: opensheets
services:
# ============================================
# Serviço: PostgreSQL (Banco de dados)
# ============================================
db:
image: postgres:18-alpine
container_name: opensheets_postgres
restart: unless-stopped
environment:
POSTGRES_USER: ${POSTGRES_USER:-opensheets}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-opensheets_dev_password}
POSTGRES_DB: ${POSTGRES_DB:-opensheets_db}
POSTGRES_INITDB_ARGS: "-E UTF8 --locale=C"
ports:
- "${DB_PORT:-5432}:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
- ./scripts/postgres/init.sql:/docker-entrypoint-initdb.d/init.sql:ro
healthcheck:
test:
[
"CMD-SHELL",
"pg_isready -U ${POSTGRES_USER:-opensheets} -d ${POSTGRES_DB:-opensheets_db}",
]
interval: 10s
timeout: 5s
retries: 5
start_period: 10s
networks:
- opensheets_network
# ============================================
# Serviço: Aplicação Next.js (imagem do Docker Hub)
# ============================================
app:
# IMPORTANTE: Substitua 'seu-usuario' pelo seu username do Docker Hub
# Exemplo: felipecoutinho/opensheets:latest
image: ${DOCKER_USERNAME:-seu-usuario}/opensheets:${IMAGE_TAG:-latest}
container_name: opensheets_app
restart: unless-stopped
ports:
- "${APP_PORT:-3000}:3000"
environment:
NODE_ENV: production
# Database URL
DATABASE_URL: ${DATABASE_URL}
# Better Auth (OBRIGATÓRIO)
BETTER_AUTH_SECRET: ${BETTER_AUTH_SECRET}
BETTER_AUTH_URL: ${BETTER_AUTH_URL:-http://localhost:3000}
# Email (opcional)
RESEND_API_KEY: ${RESEND_API_KEY:-}
EMAIL_FROM: ${EMAIL_FROM:-}
# OAuth (opcional)
GOOGLE_CLIENT_ID: ${GOOGLE_CLIENT_ID:-}
GOOGLE_CLIENT_SECRET: ${GOOGLE_CLIENT_SECRET:-}
GITHUB_CLIENT_ID: ${GITHUB_CLIENT_ID:-}
GITHUB_CLIENT_SECRET: ${GITHUB_CLIENT_SECRET:-}
# AI Providers (opcional)
ANTHROPIC_API_KEY: ${ANTHROPIC_API_KEY:-}
OPENAI_API_KEY: ${OPENAI_API_KEY:-}
GOOGLE_GENERATIVE_AI_API_KEY: ${GOOGLE_GENERATIVE_AI_API_KEY:-}
OPENROUTER_API_KEY: ${OPENROUTER_API_KEY:-}
depends_on:
db:
condition: service_healthy
networks:
- opensheets_network
# Script de inicialização: roda migrations antes de iniciar
entrypoint: ["/bin/sh", "-c"]
command:
- |
echo "🚀 Aguardando banco de dados..."
sleep 5
echo "📦 Rodando migrations..."
pnpm db:push || echo "⚠️ Migrations falharam ou já estão atualizadas"
echo "✅ Iniciando aplicação Next.js..."
node server.js
healthcheck:
test:
[
"CMD",
"wget",
"--quiet",
"--tries=1",
"--spider",
"http://localhost:3000/api/health",
]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
# ============================================
# Volumes
# ============================================
volumes:
postgres_data:
name: opensheets_postgres_data
driver: local
# ============================================
# Networks
# ============================================
networks:
opensheets_network:
name: opensheets_network
driver: bridge