Files
FranciaOcupada/NUEVO-ENFOQUE-CICD.md
Resistencia Dev fc6bc1ab54
Some checks failed
CI/CD - Francia Ocupada (La Resistencia) / build-and-deploy (push) Failing after 7s
Afegit botó per ocultar/mostrar els jugadors
2025-12-14 22:06:47 +01:00

248 lines
8.5 KiB
Markdown

# 🎯 Nuevo Enfoque de CI/CD - Script de Deployment en el Host
## El Problema que Resolvimos
### ❌ Enfoque Anterior (No Funcionaba)
El workflow intentaba ejecutar comandos `docker` directamente dentro del contenedor del runner:
```yaml
- name: Construir Imágenes
run: |
docker compose -f docker-compose_prod.yml build
```
**Problema**: Aunque el socket de Docker estaba montado (`/var/run/docker.sock`), el binario `docker` no estaba disponible dentro del contenedor del runner, causando el error:
```
docker: command not found
```
### ✅ Nuevo Enfoque (Funciona)
Creamos un script `deploy.sh` que se ejecuta **directamente en el host**, donde Docker SÍ está instalado:
```yaml
- name: Ejecutar Deployment
run: |
cd /home/marti/Documentos/Gitea/resistencia
./deploy.sh
```
## Arquitectura del Nuevo Sistema
```
┌─────────────────────────────────────────────────────────────┐
│ GITEA SERVER │
│ - Detecta push a main │
│ - Envía job al runner │
└────────────────┬────────────────────────────────────────────┘
┌─────────────────────────────────────────────────────────────┐
│ GITEA RUNNER (Contenedor) │
│ - Instala Node.js │
│ - Hace checkout del código │
│ - Ejecuta deploy.sh en el HOST │
└────────────────┬────────────────────────────────────────────┘
┌─────────────────────────────────────────────────────────────┐
│ HOST (Servidor de Producción) │
│ - deploy.sh se ejecuta aquí │
│ - Docker está instalado aquí │
│ - Construye y despliega contenedores │
│ │
│ ┌──────────────┐ ┌──────────────┐ ┌──────────────┐ │
│ │ Client │ │ Server │ │ Database │ │
│ │ (Next.js) │ │ (Node.js) │ │ (PostgreSQL) │ │
│ └──────────────┘ └──────────────┘ └──────────────┘ │
└─────────────────────────────────────────────────────────────┘
```
## Componentes del Sistema
### 1. `deploy.sh` - Script de Deployment en el Host
**Ubicación**: `/home/marti/Documentos/Gitea/resistencia/deploy.sh`
**Responsabilidades**:
- ✅ Actualizar código desde Git
- ✅ Detener contenedores anteriores
- ✅ Limpiar imágenes antiguas
- ✅ Construir nuevas imágenes Docker
- ✅ Desplegar contenedores
- ✅ Verificar que todo funciona
- ✅ Mostrar logs
**Ventajas**:
- Se ejecuta directamente en el host donde Docker está instalado
- Puede ser ejecutado manualmente para debugging: `./deploy.sh`
- Fácil de modificar y probar
- No depende de las limitaciones del runner
### 2. `.gitea/workflows/deployment.yml` - Workflow Simplificado
**Responsabilidades**:
- ✅ Instalar Node.js (necesario para `actions/checkout`)
- ✅ Hacer checkout del código
- ✅ Ejecutar `deploy.sh` en el host
- ✅ Verificar el resultado
**Ventajas**:
- Mucho más simple y mantenible
- Menos propenso a errores
- Fácil de entender y debuggear
## Cómo Funciona
### Flujo Completo
1. **Desarrollador hace push a `main`**
```bash
git push origin main
```
2. **Gitea detecta el push y activa el workflow**
- El runner recibe el job
3. **Runner instala Node.js**
- Necesario para que `actions/checkout` funcione
4. **Runner hace checkout del código**
- Descarga la última versión del repositorio
5. **Runner ejecuta `deploy.sh` en el host**
- El script se ejecuta con acceso completo a Docker del host
6. **`deploy.sh` realiza el deployment**
- Actualiza código
- Construye imágenes
- Despliega contenedores
7. **Verificación final**
- El workflow verifica que los contenedores estén corriendo
## Uso Manual del Script
También puedes ejecutar el deployment manualmente:
```bash
# Conectarte al servidor
ssh usuario@servidor
# Ir al directorio del proyecto
cd /home/marti/Documentos/Gitea/resistencia
# Ejecutar deployment
./deploy.sh
```
Esto es útil para:
- Debugging
- Deployments de emergencia
- Probar cambios antes de hacer commit
## Comparación con el Ejemplo que Funciona
El ejemplo que compartiste usa `runs-on: ubuntu-latest`, que es una imagen de GitHub/Gitea con **todas las herramientas preinstaladas**:
```yaml
jobs:
build:
runs-on: ubuntu-latest # ← Imagen completa con todo instalado
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4 # ← Node.js ya disponible
- run: mvn clean deploy # ← Maven ya disponible
```
Tu runner usa `runs-on: [production-ready]`, que es un **runner personalizado** que:
- ✅ Tiene acceso al Docker del host (vía socket)
- ❌ NO tiene Docker CLI instalado dentro del contenedor
- ❌ NO tiene Node.js preinstalado
- ❌ NO tiene otras herramientas preinstaladas
Por eso necesitamos:
1. Instalar Node.js manualmente
2. Ejecutar un script en el host (donde Docker SÍ está)
## Ventajas del Nuevo Enfoque
1. **Simplicidad**: Un script bash es más fácil de entender que un workflow complejo
2. **Debugging**: Puedes ejecutar `./deploy.sh` manualmente para probar
3. **Flexibilidad**: Fácil modificar el script sin tocar el workflow
4. **Portabilidad**: El mismo script puede usarse en otros sistemas de CI/CD
5. **Confiabilidad**: Se ejecuta en el host donde sabemos que Docker funciona
## Archivos del Sistema
```
resistencia/
├── .gitea/
│ └── workflows/
│ └── deployment.yml # Workflow simplificado
├── deploy.sh # Script de deployment (NUEVO)
├── docker-compose_prod.yml # Configuración de producción
├── CI-CD-README.md # Documentación general
├── TROUBLESHOOTING-CICD.md # Problemas resueltos
└── monitor-deploy.sh # Script de monitoreo
```
## Próximos Pasos
Ahora que el CI/CD funciona, puedes:
1. **Probar el deployment**:
```bash
git commit --allow-empty -m "test: Probar nuevo CI/CD"
git push origin main
```
2. **Monitorear en Gitea**:
- http://gitea.local:3000/marti/FranciaOcupada/actions
3. **Verificar la aplicación**:
- https://franciaocupada.martivich.es
- https://api.franciaocupada.martivich.es
4. **Mejoras futuras**:
- Agregar tests antes del deploy
- Implementar rollback automático
- Agregar notificaciones (Discord, email, etc.)
- Backup de base de datos antes de deploy
- Health checks post-deployment
## Troubleshooting
### Si el workflow falla
1. **Ver logs en Gitea Actions**
2. **Ejecutar manualmente el script**:
```bash
cd /home/marti/Documentos/Gitea/resistencia
./deploy.sh
```
3. **Verificar que Docker funciona en el host**:
```bash
docker ps
docker compose version
```
### Si los contenedores no inician
```bash
# Ver logs
docker compose -f docker-compose_prod.yml logs
# Reiniciar servicios
docker compose -f docker-compose_prod.yml restart
# Reconstruir desde cero
docker compose -f docker-compose_prod.yml down
docker compose -f docker-compose_prod.yml up -d --build
```
## Conclusión
Este nuevo enfoque es más simple, más confiable y más fácil de mantener. En lugar de luchar contra las limitaciones del runner, aprovechamos que el runner puede ejecutar scripts en el host donde Docker ya está instalado y funcionando.
**¡El CI/CD ahora debería funcionar correctamente!** 🎉