Experimenting with flux2 on microk8s
In which I try to get flux2 working on microk8s...
data:image/s3,"s3://crabby-images/0bd15/0bd1524dd9b082d6c6cd6b2ce2b25d58930796b3" alt="Experimenting with flux2 on microk8s"
Flux is a tool for configuring Kubernetes clusters using Git repositories. Changes in configuration pushed to a GitHub repo are then pushed to the cluster. This enables a GitOps-style approach to application infrastructure management.
microk8s is a minimal but complete Kubernetes distribution available from Canonical. It is fully containerized as a snap package which is easy to install and run.
Spun up a dedicated VPS on Vultr, SSH'd in, and ran OS updates:
apt update ; apt upgrade -y
data:image/s3,"s3://crabby-images/7151c/7151c57ec959df3f895f8bd0c22c9a7522c775ec" alt=""
Installed microk8s:
snap install microk8s --classic
data:image/s3,"s3://crabby-images/be9ca/be9cabf53ea114df4acd88ef91ea30690e823653" alt=""
Confirmed microk8s was up and running:
microk8s status --wait-ready
data:image/s3,"s3://crabby-images/610d8/610d8f739622a31c5f67cd441c485f78a95879f6" alt=""
The snap of flux is flux 1.x, so to get install flux2, it is necessary to use the install script:
Installed flux2:
curl -s https://toolkit.fluxcd.io/install.sh | sudo bash
data:image/s3,"s3://crabby-images/758c8/758c89a6700b9db1b5385a86d3017c5bdff0b2ee" alt=""
Ran the flux prerequisites check:
flux check --pre
data:image/s3,"s3://crabby-images/7a4eb/7a4ebea7eb4f2a2f7815fe55f170c352d93256ec" alt=""
flux2 doesn't detect the kubectl alias.
Looked at the source of flux2 where error is being generated, it is looking for kubectl in the OS PATH variable.
Create a kubectl wrapper script:
nano /usr/local/bin/kubectl
Copy and paste the following wrapper script:
#!/bin/bash
microk8s kubectl "$@"
Made the wrapper executable:
chmod u+x /usr/local/bin/kubectl
Tested executable:
kubectl version
data:image/s3,"s3://crabby-images/85f67/85f67e4b16ca8d300e106035f60a176506cb97b3" alt=""
Re-ran flux prerequisites check:
flux check --pre
data:image/s3,"s3://crabby-images/6c2e8/6c2e819d5187957a79f5f1f22db30c33400db82e" alt=""
kubectl is detected, but kubernetes client initialization is now failing.
Troubleshooting attempted:
- Looked at the source of flux2 where error is being generated.
- Used kubectl config view to get the IP of our cluster and set the KUBERNETES_MASTER variable, did not work.
data:image/s3,"s3://crabby-images/c85c4/c85c4f181d1211a97194a39833ac38bcfb62b539" alt=""
- Checked ~/.kube for a config file, not there. Found the kubeconfig used by microk8s deep in the snap, linked it to ~/.kube/config, success!
data:image/s3,"s3://crabby-images/ce90a/ce90ae689058daf01d6907177067b57333b8b88f" alt=""
Set my GitHub PAT and username:
export GITHUB_TOKEN=<token>
export GITHUB_USER=sirredbeard
data:image/s3,"s3://crabby-images/ea2ae/ea2ae8ede4932ff01ccdde7e3f2adbacdcae94f0" alt=""
Bootstrapped my repository:
flux bootstrap github \
--owner=$GITHUB_USER \
--repository=flux-sandbox \
--branch=main \
--path=./clusters/my-cluster \
--personal
data:image/s3,"s3://crabby-images/c3f70/c3f708b521dec07cdc5ef4936ff176957373bb3d" alt=""
Received error:
unable to clone 'ssh://git@github.com/sirredbeard/flux-sandbox', error: dial tcp: lookup github.com: Try again
data:image/s3,"s3://crabby-images/a79c3/a79c37f5cc5cb9452db0d42e704aae5def89473e" alt=""
Confirmed GitHub repository was created:
data:image/s3,"s3://crabby-images/d52ae/d52aea99d0d25a6aaec002dee80a27c6890bfdc5" alt=""
Re-ran bootstrap command, no change.
Looked for logs. Probably in source-controller:
kubectl -n flux-system logs source-controller-65f5b6cb7c-ct7k8
data:image/s3,"s3://crabby-images/1bb12/1bb12d6d02852ab6bec06fbdf3c540181344c1a5" alt=""
Looks like source-controller can't reach notification-controller or github.com, odd.
Confirm DNS is enabled:
microk8s enable dns
data:image/s3,"s3://crabby-images/8a800/8a80018558f2e94122e4039ccb141e8666998798" alt=""
There is some networking thing here I am not seeing. Taking a break to return to it later...
Continuing: I ran the issue by the Kubernetes team, something about it just did not seem right, and it turns out this is a DNS bug.
The temporary workaround stated is to convert to a non-HA cluster, which I did as followed:
microk8s disable ha-cluster
microk8s disable dns
microk8s stop
microk8s start
microk8s enable dns
data:image/s3,"s3://crabby-images/6b80c/6b80c0bb56365707317e274eba785f86ea64b87b" alt=""
Re-ran the bootstrap script, and success!
data:image/s3,"s3://crabby-images/9c257/9c2571d67dd535644e1968999ab304590b1e02b2" alt=""
I then connected to the VPS over SSH using VS Code and git cloned my flux-sandbox repo to my home folder:
data:image/s3,"s3://crabby-images/edd34/edd342d996ca887f9023c45fd22ed3d8e8c7111b" alt=""
data:image/s3,"s3://crabby-images/7bf4a/7bf4adb6cea1de7590e635f0e0ddb8c17b3e4884" alt=""
I then added the repository for a sample app, podinfo, from the flux2 Get Started guide to my deployment:
flux create source git podinfo \
--url=https://github.com/stefanprodan/podinfo \
--branch=master \
--interval=30s \
--export > ./clusters/my-cluster/podinfo-source.yaml
data:image/s3,"s3://crabby-images/12fe5/12fe5f6206ecaaa922c1570c55369839b98f8858" alt=""
This created the postinfo-source.yaml manifest (below), which I then committed and pushed to GitHub from VS Code:
data:image/s3,"s3://crabby-images/5c652/5c6529f7fed56e54c74592981de90276a7301fe9" alt=""
Next, I then deployed the podinfo app by creating a Flux Kustomization manifest for podinfo:
flux create kustomization podinfo \
--source=podinfo \
--path="./kustomize" \
--prune=true \
--validation=client \
--interval=5m \
--export > ./clusters/my-cluster/podinfo-kustomization.yaml
data:image/s3,"s3://crabby-images/34fa5/34fa514fa211dcff5a2f3d1f46e43154eddff7ed" alt=""
Which I then committed and pushed.
data:image/s3,"s3://crabby-images/1a423/1a42381a1ebf0ea140376e9d78852695b387bcc9" alt=""
And confirmed running:
kubectl get pods --all-namespaces
data:image/s3,"s3://crabby-images/6887d/6887dabb5f99cc053e336e6811cc281cbbc614e5" alt=""
Pausing for now.