Skip to content

Gatemaster Flux Ping-Pong simplifies Kubernetes application deployment and management on DigitalOcean, using PostgreSQL, Helm, and Flux for robust infrastructure. With CD and GitOps, it ensures a smooth workflow, integrating Let's Encrypt, GoDaddy DNS, an Ingress Controller, and a Load Balancer for enhanced security and accessibility.

Notifications You must be signed in to change notification settings

Frnn4268/Gatemaster-flux-ping-pong

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Gatemaster-flux-ping-pong

Este repositorio contiene la configuración necesaria para implementar una aplicación de servidor HTTP simple llamada Pong en un clúster de Kubernetes usando Flux CD.

Prerrequisitos

Antes de comenzar, asegúrese de tener lo siguiente instalado localmente:

  • Un Kubernetes cluster (en este experimento, usamos Kind o también puede ser un proveedor de la nube como DigitalOcean)
  • kubectl
  • Flux CLI
  • GitHub Personal Access Token con acceso al repositorio
  • GitHub CLI
  • doctl

Preparando el repositorio Git

Para preparar su repositorio Git, siga estos pasos:

  1. Crea un nuevo directorio e inicializa un repositorio Git:

    mkdir Gatemaster-flux-ping-pong
    cd Gatemaster-flux-ping-pong
    git init
  2. Crear un directorio llamado manifests para guardar los Kubernetes manifests:

    mkdir manifests

Creación de manifiestos de implementación y servicio

Cree los siguientes archivos de manifiesto en el directorio manifests:

  1. Desplegar los Manifest: Crear pong-deployment.yaml:

    apiVersion: apps/v1

kind: Deployment metadata: name: pong-server-deployment namespace: pong-namespace
spec: replicas: 1 selector: matchLabels: app: pong-server template: metadata: labels: app: pong-server spec: containers: - name: pong-server image: ghcr.io/s1ntaxe770r/pong:e0fb83f27536836d1420cffd0724360a7a650c13 ports: - containerPort: 8080 ```

  1. Servicio Manifest: Crear pong-service.yaml:

    apiVersion: v1

kind: Service metadata: name: pong-server-service namespace: pong-namespace spec: selector: app: pong-server ports: - protocol: TCP port: 80 targetPort: 8080 ```

  1. Agregue y confirme estos archivos en Git:

    git add .
    git commit -m "Añadiendo manifests de despliegue"
  2. Crea el repositorio de GitHub y envía tus cambios:

    gh repo create Gatemaster-flux-ping-pong --source=. --remote=upstream --public
    git push --set-upstream upstream master

Inicio de Sesión en DigitalOcean

Si está utilizando DigitalOcean para su clúster de Kubernetes, inicie sesión con doctl:

  1. Autenticación con DigitalOcean:

    doctl auth init
  2. Lista tus clusters de Kubernetes:

    doctl kubernetes cluster list

Bootstrapping Flux

Para iniciar Flux y configurarlo para monitorear su repositorio de GitHub:

  1. Cree un clúster Kind o utilice un clúster Kubernetes de DigitalOcean existente:

    kind create cluster --image kindest/node:v1.28.0 --name flux-cluster
  2. Verificar el estado del cluster:

    kubectl cluster-info
  3. Ejecutar comprobaciones previas a la instalación:

    flux check --pre
  4. Exporta tus credenciales de GitHub:

    export GITHUB_TOKEN=<your-token>
    export GITHUB_USER=<your-username>
  5. Ejecute el comando bootstrap:

    flux bootstrap github \
      --owner=$GITHUB_USER \
      --repository=Gatemaster-flux-ping-pong \
      --branch=master \
      --path=clusters/my-cluster
  6. Verifique la instalación de Flux:

    kubectl get pods -n flux-system
  7. Pull los últimos cambios:

    git pull

Cambiando de Namespace

Para cambiar el namespace de tu Pong deployment and service:

  1. Crear un nuevo namespace:

    kubectl create namespace pong-namespace
  2. Modifica tu pong-service.yaml y pong-deployment.yaml para incluir el campo manifest:

    metadata:
        namespace: pong-namespace
  3. Aplicar los cambios:

    kubectl apply -f pong-deployment.yaml -n pong-namespace
    kubectl apply -f pong-service.yaml -n pong-namespace
  4. Verificar los pods dentro del nuevo namespace:

    kubectl get pods -n pong-namespace

Automatización de implementaciones con Flux

Para configurar Flux para implementar sus manifests:

  1. Definir el recurso GitRepository:

    flux create source git pong \
      --url="https://github.com/$GITHUB_USER/Gatemaster-flux-ping-pong" \
      --branch=master \
      --interval=30s \
      --export > ./clusters/my-cluster/pong-source.yaml
  2. Definir el recurso Kustomization:

    flux create kustomization pong \
      --target-namespace=default \
      --source=pong \
      --path="./manifests" \
      --prune=true \
      --interval=5m \
      --export > ./clusters/my-cluster/pong-kustomization.yaml
  3. Inspeccionar el manifest generado:

    cat ./clusters/my-cluster/pong-kustomization.yaml
  4. Commit y push los manifests generados:

    git add clusters/
    git commit -m "Añadiendo kustomize manifests"
    git push
  5. Esperando a que Flux sincronice la aplicación:

    flux get kustomizations --watch
  6. Verificar el despliegue:

    kubectl port-forward svc/pong-server-service 8080:80 -n pong-namespace
    curl http://localhost:8080/ping

Actualizando la aplicación de Pong con Flux

Para actualizar el despliegue:

  1. Editar el archivo pong-deployment.yaml para incrementar las replicas:

    replicas: 3
  2. Guardar, commit, y hacerle push a los cambios:

    git add pong-deployment.yaml
    git commit -m "Escalando el despliegue de pong a 3 replicas"
    git push origin master
  3. Verificar la actualización:

    flux logs
    kubectl get pods -n pong-namespace

Solución de problemas

  • Servicio no encontrado: si encuentra el mensaje services "pong-server-service" not found, verifique que el servicio esté correctamente definido e implementado.
  • Problemas de conexión: asegúrese de que el reenvío de puertos esté configurado correctamente y verifique si la aplicación se está ejecutando correctamente dentro de los pods.

About

Gatemaster Flux Ping-Pong simplifies Kubernetes application deployment and management on DigitalOcean, using PostgreSQL, Helm, and Flux for robust infrastructure. With CD and GitOps, it ensures a smooth workflow, integrating Let's Encrypt, GoDaddy DNS, an Ingress Controller, and a Load Balancer for enhanced security and accessibility.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published