Skip to content

Latest commit

 

History

History
423 lines (315 loc) · 9.9 KB

README.md

File metadata and controls

423 lines (315 loc) · 9.9 KB

Flux Workshop - Nerdearla 2023

Este repo es complementario al workshop Introducción a GitOps con Flux, dado en la Introducción a GitOps con Flux.

Requisitos

Forkea este repo

# Clone
export GITHUB_USERNAME=<user>

git clone [email protected]:$GITHUB_USERNAME/flux-workshop-nerdearla.git

cd flux-workshop-nerdearla

# Fetch del branch init
git fetch origin init

# Merge con main
git merge origin/init

Tools

Mi setup

  • colima 0.5.5
  • kubectl 1.28.2
  • flux 2.1.1

Crear cluster

colima start --kubernetes --cpu 8 --memory 8 --profile flux-demo

# kind
kind create cluster --name flux-demo
Colima output INFO[0000] starting colima [profile=flux-demo] INFO[0000] runtime: docker+k3s INFO[0000] preparing network ... context=vm INFO[0000] creating and starting ... context=vm INFO[0024] provisioning ... context=docker INFO[0025] starting ... context=docker INFO[0031] provisioning ... context=kubernetes INFO[0031] downloading and installing ... context=kubernetes INFO[0038] loading oci images ... context=kubernetes INFO[0045] starting ... context=kubernetes INFO[0048] updating config ... context=kubernetes INFO[0049] Switched to context "colima-flux-demo". context=kubernetes INFO[0051] done

Check la creación del cluster

kubectl get nodes --watch

Instalar Flux en el cluster

Primero vas a necesitar un token personal de Github con todos los permisos del scope repo - https://github.com/settings/tokens.

export GITHUB_USER=<github-user>
export GITHUB_TOKEN=<github-token>

Chequear compatibilidad de flux con nuestro cluster

flux check --pre

► checking prerequisites
✔ Kubernetes 1.28.1+k3s1 >=1.25.0-0
✔ prerequisites checks passed

Flux bootstrap

flux bootstrap github \
  --owner=$GITHUB_USER \
  --repository=flux-workshop-nerdearla \
  --branch=main \
  --path=./clusters/dev \
  --personal \
  --read-write-key
Output
► connecting to github.com
► cloning branch "main" from Git repository "https://github.com/marcorichetta/flux-workshop-nerdearla.git"
✔ cloned repository
► generating component manifests
✔ generated component manifests
✔ committed sync manifests to "main" ("128f2feb9053ed1863b3e5a8c14cf65488512b12")
► pushing component manifests to "https://github.com/marcorichetta/flux-workshop-nerdearla.git"
► installing components in "flux-system" namespace
✔ installed components
✔ reconciled components
► determining if source secret "flux-system/flux-system" exists
► generating source secret
✔ public key: ecdsa-sha2-nistp384 AAAAE2VjZHNhLXNoYTItbmlzdHAzODQAAAAIbmlzdHAzODQAAABhBNf54MZoM/zhM6DdYxJwyHf8PY2B6+VVobMzy+2kmpP0jSfFe4alVUbW0t/ljzeJyss5zj75Raw31z7LC7dH8LJZBzamVCmvX4g80S1EUzkbBLkhj0y4++YlLhcE51/19g==
✔ configured deploy key "flux-system-main-flux-system-./clusters/dev" for "https://github.com/marcorichetta/flux-workshop-nerdearla"
► applying source secret "flux-system/flux-system"
✔ reconciled source secret
► generating sync manifests
✔ generated sync manifests
✔ committed sync manifests to "main" ("0426a12bd7de1dc4186311a6bd5f8835d1340212")

Ver como se levanta flux

kubectl get pods -n flux-system -w

Traerse los manifiestos commiteados por flux

git pull

lsd --tree clusters
clusters
└── dev
    └── flux-system
        ├── gotk-components.yaml
        ├── gotk-sync.yaml
        └── kustomization.yaml

Suspender flux

flux suspend kustomization flux-system -n flux-system

Approach tradicional

Crear apps con kubectl

kubectl apply -R -f apps/dev

kubectl port-forward svc/frontend -n podinfo 8000:9898

kubectl get all -n podinfo

kubectl edit -n podinfo deploy/frontend

Resumir flux

flux resume kustomization flux-system -n flux-system

Gitops way

Crear namespace podinfo

# apps/podinfo/namespace.yaml
apiVersion: v1
kind: Namespace
metadata:
    name: podinfo

Crear kustomization

flux create kustomization apps \
  --source=flux-system \
  --path="./apps/dev" \
  --prune=true \
  --interval=5m \
  --export > ./clusters/dev/apps.yaml

Forzar reconciliación de Flux 💡

flux reconcile kustomization apps --with-source

Crear kustomization para notificar a Flux del dashboard

flux create kustomization infra \
--source=flux-system \
--path="./infrastructure" \
--prune=true \
--interval=1h \
--export > ./clusters/dev/infrastructure.yaml

# Port forward para ingresar localmente
kubectl port-forward svc/weave-gitops -n flux-system 9001:9001

Image automation

Agregar image automation y reflector controllers

flux bootstrap github \
  --components-extra=image-reflector-controller,image-automation-controller \
  --owner=$GITHUB_USER \
  --repository=flux-workshop-nerdearla \
  --branch=main \
  --path=./clusters/dev \
  --personal \
  --read-write-key
kubectl get deploy -n flux-system

⚠️ git pull para traerse los cambios que pusheo flux ⚠️

Configurar image scanning

mkdir ./clusters/dev/images/

flux create image repository podinfo \
--image=ghcr.io/stefanprodan/podinfo \
--interval=5m \
--export > ./clusters/dev/images/podinfo-registry.yaml

Image update automation

Crear la policy a ser aplicada por Flux

flux create image policy podinfo \
--image-ref=podinfo \
--select-semver=">=5.0.x" \
--export > ./clusters/dev/images/podinfo-policy.yaml

Ejemplos: https://fluxcd.io/flux/guides/image-update/#imagepolicy-examples

Conectar policy con app

# deployment.yaml

spec:
    containers:
        - name: frontend
          image: ghcr.io/stefanprodan/podinfo:5.0.0 # {"$imagepolicy": "flux-system:podinfo"}

Crear update automation

flux create image update flux-system \
--interval=30m \
--git-repo-ref=flux-system \
--git-repo-path="./apps/dev" \
--checkout-branch=main \
--push-branch=main \
--author-name=fluxcdbot \
[email protected] \
--commit-template="{{range .Updated.Images}}{{println .}}{{end}}" \
--export > ./clusters/dev/flux-system-automation.yaml

Reproducibility

Borrar cluster

kind delete cluster -n flux-demo

colima stop --profile flux-demo
colima delete --profile flux-demo

Recrearlos

kind create cluser -n new-flux-demo

colima start --kubernetes --cpu 4 --memory 8 --profile new-flux-demo

Reboot Flux

flux bootstrap github \
  --components-extra=image-reflector-controller,image-automation-controller \
  --owner=$GITHUB_USER \
  --repository=flux-workshop-nerdearla \
  --branch=main \
  --path=./clusters/dev \
  --personal \
  --read-write-key

kubectl port-forward svc/weave-gitops -n flux-system 9001:9001

Problem: "I can manage all my K8s config in git, except Secrets." Sealed Secrets: "Hold my beer"

Instalar Sealed Secrets Controller

mkdir ./clusters/dev/sealed-secrets

flux create source helm sealed-secrets \
    --url=https://bitnami-labs.github.io/sealed-secrets \
    --interval=10m \
    --export > ./clusters/dev/sealed-secrets/source.yaml

flux create helmrelease sealed-secrets \
    --interval=1h \
    --release-name=sealed-secrets-controller \
    --target-namespace=flux-system \
    --source=HelmRepository/sealed-secrets \
    --chart=sealed-secrets \
    --chart-version=">=1.15.0-0" \
    --crds=CreateReplace \
    --export > ./clusters/dev/sealed-secrets/helmrelease.yaml

Obtener la Public Key para crear secrets

kubeseal --fetch-cert \
    --controller-name=sealed-secrets-controller \
    --controller-namespace=flux-system \
    > ./clusters/dev/sealed-secrets/pub-sealed-secrets.pem

Crear Secret

kubectl -n default create secret generic podinfo-secret \
    --from-literal=SECRET_KEY=super_secret_key \
    --dry-run=client \
    -o yaml > apps/dev/podinfo/secret.yaml

Crear Sealed Secret

kubeseal --scope cluster-wide \
    --format=yaml \
    --cert=./clusters/dev/sealed-secrets/pub-sealed-secrets.pem \
    -f apps/dev/podinfo/secret.yaml \
    -w apps/dev/podinfo/sealed-secret.yaml

Agregar env en deployment.yaml y agregarlo en kustomization.yaml

# deployment.yaml
- name: SECRET_KEY
    valueFrom:
        secretKeyRef:
            name: podinfo-secret
            key: SECRET_KEY

# kustomization.yaml
resources:
- ./podinfo/sealed-secret.yaml

5 minutes later

kubectl get secret podinfo-secret -o jsonpath={.data.SECRET_KEY} | base64 -d

Notificaciones

Crear provider

mkdir ./clusters/dev/notifications

flux create alert-provider generic --type generic --export > ./clusters/dev/notifications/provider.yaml

Crear alert

flux create alert generic-alert \
  --event-severity info \
  --event-source Kustomization/flux-system \
  --provider-ref generic \
  --export > ./clusters/dev/notifications/alert.yaml