Ir al contenido

Ejemplos de flujos CI/CD

Ejemplos paso a paso para flujos de trabajo CI/CD comunes. Cada ejemplo muestra el prompt en lenguaje natural y las acciones de meta-tools que el servidor ejecuta.

sequenceDiagram
    participant U as Usuario
    participant AI as Asistente IA
    participant MCP as MCP Server
    participant GL as API de GitLab

    U->>AI: "Muéstrame pipelines fallidos"
    AI->>MCP: gitlab_pipeline (action: list)
    MCP->>GL: GET /projects/:id/pipelines
    GL-->>MCP: Lista de pipelines
    MCP-->>AI: Pipelines fallidos
    AI->>U: "Se encontraron 2 pipelines fallidos"
    U->>AI: "Muéstrame los jobs fallidos en #45892"
    AI->>MCP: gitlab_pipeline (action: job_list)
    MCP->>GL: GET /projects/:id/pipelines/:id/jobs
    GL-->>MCP: Detalles de jobs
    MCP-->>AI: Jobs fallidos
    AI->>MCP: gitlab_pipeline (action: job_log)
    MCP->>GL: GET /projects/:id/jobs/:id/trace
    GL-->>MCP: Salida del log
    MCP-->>AI: Logs del job
    AI->>U: Análisis de causa raíz + solución

Prompt: “Muéstrame todos los pipelines fallidos en my-group/backend”

gitlab_pipeline → action: list, project_id: "my-group/backend", status: "failed"

Devuelve: IDs de pipelines, ramas, razones de fallo y duraciones.

Prompt: “Muéstrame los jobs fallidos en el pipeline #45892”

gitlab_pipeline → action: job_list, project_id: "my-group/backend", pipeline_id: 45892, scope: "failed"

Devuelve: nombres de jobs, stages, mensajes de error e información del runner.

Prompt: “Obtén la salida del log del job ‘test-integration’ en el pipeline #45892”

gitlab_pipeline → action: job_log, project_id: "my-group/backend", job_id: 98765

Devuelve: salida completa del log del job. Útil para diagnosticar fallos en tests sin abrir la interfaz de GitLab.

Prompt: “Analiza por qué falló el pipeline #45892 y sugiere correcciones”

gitlab_analyze_pipeline_failure (sampling) → obtiene logs de jobs, identifica causa raíz, sugiere correcciones

El servidor usa sampling LLM para leer logs de jobs, correlacionar errores entre stages y proporcionar pasos de remediación accionables.


Prompt: “¿Qué variables CI/CD están configuradas en el proyecto backend?”

gitlab_ci_variable → action: project_list, project_id: "my-group/backend"

Devuelve: claves de variables, estado de protección, estado de enmascaramiento y ámbitos de entorno. Los valores están enmascarados por seguridad.

Prompt: “Añade una variable CI/CD DEPLOY_TOKEN con valor ‘abc123’ al proyecto backend, enmascarada y protegida”

gitlab_ci_variable → action: project_create, project_id: "my-group/backend",
key: "DEPLOY_TOKEN", value: "abc123", masked: true, protected: true

Prompt: “Actualiza la variable DATABASE_URL en backend para que solo aplique al entorno de producción”

gitlab_ci_variable → action: project_update, project_id: "my-group/backend",
key: "DATABASE_URL", environment_scope: "production"

Prompt: “Crea una programación de pipeline que se ejecute cada noche a las 2 AM UTC en la rama main”

gitlab_pipeline → action: schedule_create, project_id: "my-group/backend",
description: "Nightly build", ref: "main", cron: "0 2 * * *", cron_timezone: "UTC"

Prompt: “Muéstrame todas las programaciones de pipeline en el proyecto backend”

gitlab_pipeline → action: schedule_list, project_id: "my-group/backend"

Devuelve: descripciones, expresiones cron, próximas ejecuciones e información del propietario.


Prompt: “Muéstrame todos los entornos del proyecto backend”

gitlab_environment → action: list, project_id: "my-group/backend"

Devuelve: nombres de entornos, URLs externas, información del último despliegue y estado.

Prompt: “Muéstrame los despliegues recientes al entorno de producción”

gitlab_environment → action: deployment_list, project_id: "my-group/backend", environment: "production"

Prompt: “Detén el entorno review/feature-login en el proyecto backend”

gitlab_environment → action: stop, project_id: "my-group/backend", environment_id: 42

Prompt: “Valida el .gitlab-ci.yml en my-group/backend buscando errores de sintaxis”

gitlab_template → action: ci_lint, project_id: "my-group/backend"

Devuelve: estado de validación, YAML fusionado, advertencias y detalles de errores.

Prompt: “Revisa la configuración CI en my-group/backend buscando mejores prácticas”

gitlab_analyze_ci_configuration (sampling) → lee .gitlab-ci.yml, analiza estructura, sugiere mejoras

Verifica: jobs redundantes, falta de caché, manejo ineficiente de artefactos, mejores prácticas de seguridad y oportunidades de paralelización.


Prompt: “Muéstrame las métricas DORA del proyecto backend en los últimos 30 días”

gitlab_dora_metrics → action: project, project_id: "my-group/backend",
metric: "all", start_date: "2024-01-01", end_date: "2024-01-31"

Devuelve: frecuencia de despliegue, tiempo de entrega para cambios, tiempo de restauración del servicio y tasa de fallo en cambios.

Prompt: “Compara las métricas DORA entre todos los proyectos del grupo platform”

gitlab_dora_metrics → action: group, group_id: "platform",
metric: "all", interval: "monthly"

Devuelve: métricas agregadas para todo el grupo, útil para dashboards de liderazgo de ingeniería.