För att man i varje ny mikrostjänst ska slippa skapa en pipeline från grunden och kompletta manifest för varje tjänst används Helm chart, som innebär att man genom att sätta ett fåtal parametrar kan generera ett komplett manifest. Det innebär också att uppdateringar kan göras centralt och pushas ut till många tjänster.
Gemensamma charts
Pipeline chart
Repository: https://gitlab.sundsvall.se/argocd/helm/spring-boot-pipeline
Namn: spring-boot-pipeline
producerar: Tekton pipeline
Service chart
Repository: https://gitlab.sundsvall.se/argocd/helm/spring-boot-chart
Namn: spring-boot-chart
producerar: Deployment manifest för tjänst
Användning
För att använda spring-boot-pipeline chart skapas en ny chart som pekar ut spring-boot-pipeline som ett dependency. Mikrotjänstens nya chart använder spring-boot-pipeline chart som en subchart. Detta innebär att mikrotjänstens chart inte behöver ha några egna templates utan använder bara det som finns i subcharten.
Dependency pekar man ut i mikrotjänstens Chart.yaml
dependencies: - name: spring-boot-pipeline version: ^0.2.* repository: http://nexus.sundsvall.se/repository/sundsvall-helm/
Mikrotjänstens chart behöver inte pushas till det Helm repository som finns i nexus. Om man i Argo cd pekar ut en katalog som innehåller en Chart.yaml används den direkt.
Generera kubernetes objekt
För att generera k8 objekt lokalt används Helm CLI. Innan man kan generera behöver man lägga till http://nexus.sundsvall.se/repository/sundsvall-helm/
som repo, se Helm Repo Add.
För att generera chart i current working directory:
$ helm template .
För att uppdatera dependency:
$ helm dependency update