För att man i varje ny mikrostjänst ska slippa skapa en pipeline från grunden och har en kompletta manifest för varje tjänst används Helm chart tagits fram, som innebär att man genom att sätta ett fåtal parametrar kan generera en ett komplett pipelinemanifest. Det innebär också att uppdateringar kan göras centralt och pushas ut till många pipelinestjä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.
...
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.
...