Kubernetes is a platform for building platforms.
Kubernetes is more than a container scheduler; it offers interfaces into a complete range of core infrastructure. In this talk we will with the power of GitOps see how we can utilize Kubernetes not only to run applications, but manage itself and provision cloud resources like databases.
The term "GitOps" term was originally coined by Weaveworks as a way to do operations by pull requests, and apply many of the same ideas behind reconciliation in kubernetes clusters to applications and clusters. This way of operating clusters enforces declarative infrastructure and serves as a source of truth for your systems. Always having the source of truth in Git provides many advantages, two of them are to always have the latest state to recover from in case of a cluster disaster, and secondly, complete audibility of what is going on in the cluster.
Setup environment variables
export AZURE_TENANT_ID=7a014d5a-2306-45a7-aca7-bf0288e80188
export AZURE_SUBSCRIPTION_ID=1eefb098-7c6a-4204-9ee9-349f23c63bbf
export AZURE_CLIENT_ID=6185cbdf-5795-4283-b9b2-3ec101f59fde
export AZURE_CLIENT_SECRET=d51fda4f-d649-4cc4-8c4a-60ae23b94ea3
export AZURE_LOCATION=westeurope
export AZURE_RESOURCE_GROUP=bitshift-gitops
export CLUSTER_NAME=bitshift-gitops-k8s
export VNET_NAME=bitshift-gitops-vnet
export OUTPUT_DIR=$(pwd)/manifests-cluster
Generate the cluster manifests
./bootstrap/generate.sh
This should output the following
manifests-cluster/
├── cluster.yaml
├── controlplane.yaml
├── machinedeployment.yaml
├── provider-components.yaml
├── sshkey
└── sshkey.pub
kubectl apply -f manifests-cluster/
clusterctl create cluster -v 4 \
--bootstrap-type kind \
--provider azure \
-m manifests-cluster/machinedeployment.yaml \
-c manifests-cluster/cluster.yaml \
-p manifests-cluster/provider-components.yaml \
-a bootstrap/cluster/addons.yaml