Flux bootstrap for Azure DevOps

How to bootstrap Flux with Azure DevOps

To install Flux on an AKS cluster using an Azure DevOps Git repository as the source of truth, you can use the flux bootstrap git command.

Azure DevOps PAT

For accessing the Azure API, the bootstrap command requires an Azure DevOps personal access token (PAT) with pull and push permissions for Git repositories.

Generate an Azure DevOps PAT and create a new repository to hold your Flux install and other Kubernetes resources.

The Azure DevOps PAT can be exported as an environment variable:

export GIT_PASSWORD=<az-token> 

If the GIT_PASSWORD env var is not set, the bootstrap command will prompt you to type it the token.

You can also supply the token using a pipe e.g. echo "<az-token>" | flux bootstrap git.

Bootstrap using a DevOps PAT

Run the bootstrap for a repository using token-based authentication:

flux bootstrap git \  --token-auth=true \  --url=https://dev.azure.com/<org>/<project>/_git/<repository> \  --branch=main \  --path=clusters/my-cluster 

When using --token-auth, the CLI and the Flux controllers running on the cluster will use the Azure DevOps PAT to access the Git repository over HTTPS.

Note that the Azure DevOps PAT is stored in the cluster as a Kubernetes Secret named flux-system inside the flux-system namespace.

Bootstrap using SSH keys

Azure DevOps SSH works only with RSA SHA-2 keys.

To configure Flux with RSA SHA-2 keys, you need to clone the DevOps locally, then create the file structure required by bootstrap with:

mkdir -p clusters/my-cluster/flux-system touch clusters/my-cluster/flux-system/gotk-components.yaml \  clusters/my-cluster/flux-system/gotk-sync.yaml \  clusters/my-cluster/flux-system/kustomization.yaml 

Edit the kustomization.yaml file to include the following patches:

apiVersion: kustomize.config.k8s.io/v1beta1 kind: Kustomization resources:  - gotk-components.yaml  - gotk-sync.yaml patches:  - patch: |  - op: add  path: /spec/template/spec/containers/0/args/-  value: --ssh-hostkey-algos=rsa-sha2-512,rsa-sha2-256   target:  kind: Deployment  name: (source-controller|image-automation-controller) 

Commit and push the changes to upstream with:

git add -A && git commit -m "init flux" && git push 

To generate an SSH key pair compatible with Azure DevOps, you’ll need to use ssh-keygen with the rsa-sha2-512 algorithm:

ssh-keygen -t rsa-sha2-512 

Upload the SSH public key to Azure DevOps. For more information, see the Azure DevOps documentation.

Run bootstrap using the SSH URL of the Azure DevOps repository and the RSA SHA-2 private key:

flux bootstrap git \  --url=ssh://git@ssh.dev.azure.com/v3/<org>/<project>/<repository>  --branch=<my-branch> \  --ssh-hostkey-algos=rsa-sha2-512,rsa-sha2-256 \  --private-key-file=<path/to/ssh/private.key> \  --password=<key-passphrase> \  --path=clusters/my-cluster 

For more information on how to use the flux bootstrap git command, please see the generic Git server documentation.