Difference between revisions of "Kubernetes/Progressive Delivery Flux and Flagger"

From Ever changing code
Jump to navigation Jump to search
Line 42: Line 42:
= References =
= References =
*[https://github.com/pio2pio/gitops-istio gitops-istio] Tutorial
*[https://github.com/pio2pio/gitops-istio gitops-istio] Tutorial
*[https://www.youtube.com/watch?v=nGLpUCPX8JE] Flux v2 Everything that you wanted to know but were afraid to ask (Stefan Prodan), Dev 2020

Revision as of 23:55, 24 May 2021

Flux

Flux v2 architecture

ClipCapIt-210524-232835.PNG

Flux v2 - Webhooks and notifications

ClipCapIt-210524-233028.PNG


Install Flux v2 flux command line

Note: fluxctl is a previous version Flux v1 command line tool.

curl -s https://fluxcd.io/install.sh | sudo bash

# enable completions in ~/.bash_profile
. <(flux completion bash)

# TODO: Via release binaries
# https://github.com/fluxcd/flux/releases

# Pre check
flux check --pre
► checking prerequisites
✔ kubectl 1.18.6 >=1.18.0-0
✔ Kubernetes 1.18.9 >=1.16.0-0
✔ prerequisites checks passed

Cluster bootstrap

FLUX_GIT_USERNAME=my-git-username
FLUX_GIT_EMAIL=my-git-email@example.com
flux bootstrap git \
  --author-email=$FLUX_GIT_EMAIL \
  --url=ssh://git@github.com/$FLUX_GIT_USERNAME/gitops-istio \
  --branch=main \
  --path=clusters/my-cluster

At bootstrap, Flux generates an SSH key and prints the public key. In order to sync your cluster state with git you need to copy the public key and create a deploy key with write access on your GitHub repository. On GitHub go to Settings > Deploy keys click on Add deploy key, check Allow write access, paste the Flux public key and click Add key.

References

  • gitops-istio Tutorial
  • [1] Flux v2 Everything that you wanted to know but were afraid to ask (Stefan Prodan), Dev 2020