Kubernetes Cloud Controller Manager for Hetzner Cloud
The Hetzner Cloud cloud controller mangager integrates your Kubernets cluster with the Hetzner Cloud API.
Read more about kubernetes cloud controller managers in the kubernetes documentation.
Features
- instances interface
Adds the server type to the
beta.kubernetes.io/instance-type
label, sets the external ipv4 and ipv6 addresses and deletes nodes from Kubernetes that where deleted from the Hetzner Cloud.
- zones interface
Makes Kubernetes aware of the failure domain of the server by setting the
failure-domain.beta.kubernetes.io/region
and failure-domain.beta.kubernetes.io/zone
labels on the node.
Example
apiVersion: v1
kind: Node
metadata:
annotations:
flannel.alpha.coreos.com/backend-data: '{"VtepMAC":"06:b3:ee:88:92:36"}'
flannel.alpha.coreos.com/backend-type: vxlan
flannel.alpha.coreos.com/kube-subnet-manager: "true"
flannel.alpha.coreos.com/public-ip: 78.46.208.178
node.alpha.kubernetes.io/ttl: "0"
volumes.kubernetes.io/controller-managed-attach-detach: "true"
creationTimestamp: 2018-01-24T15:59:45Z
labels:
beta.kubernetes.io/arch: amd64
beta.kubernetes.io/instance-type: cx11 # <-- server type
beta.kubernetes.io/os: linux
failure-domain.beta.kubernetes.io/region: fsn1 # <-- location
failure-domain.beta.kubernetes.io/zone: fsn1-dc8 # <-- datacenter
kubernetes.io/hostname: master
node-role.kubernetes.io/master: ""
name: master
resourceVersion: "183932"
selfLink: /api/v1/nodes/master
uid: 98acdedc-011f-11e8-9ed3-9600000780bf
spec:
externalID: master
podCIDR: 10.244.0.0/24
providerID: hcloud://123456 # <-- Server ID
status:
addresses:
- address: master
type: Hostname
- address: 78.46.208.178 # <-- public ipv4
type: ExternalIP
Deployment
This deployment example uses kubeadm
to bootstrap an Kubernetes cluster, with flannel as overlay network agent. Feel free to adapt the steps to your preferred method of installing Kubernetes.
These deployment instructions are designed to guide with the installation of the hcloud-cloud-controller-manager
and are by no means an in depth tutorial of setting up Kubernetes clusters.
Previous knowledge about the involved components is required.
Please refer to the kubeadm cluster creation guide, which these instructions are meant to argument and the kubeadm documentation.
- The cloud controller manager adds its labels when a node is added to the cluster. This means we have to add the
--cloud-provider=external
flag to the kubelet
before initializing the cluster master with kubeadm init
.
To do accomplish this we add this systemd drop-in unit:
/etc/systemd/system/kubelet.service.d/20-hcloud.conf
[Service]
Environment="KUBELET_EXTRA_ARGS=--cloud-provider=external"
- Now the cluster master can be initialized:
sudo kubeadm init --pod-network-cidr=10.244.0.0/16
- Configure kubectl to connect to the kube-apiserver:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
- Deploy the flannel CNI plugin:
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/v0.9.1/Documentation/kube-flannel.yml
- Patch the flannel deployment to tolerate the
uninitialized
taint:
kubectl -n kube-system patch ds kube-flannel-ds --type json -p '[{"op":"add","path":"/spec/template/spec/tolerations/-","value":{"key":"node.cloudprovider.kubernetes.io/uninitialized","value":"true","effect":"NoSchedule"}}]'
- Create a secret containing your Hetzner Cloud API token.
kubectl -n kube-system create secret generic hcloud --from-literal=token=<hcloud API token>
- Deploy the
hcloud-cloud-controller-manager
:
kubectl apply -f https://raw.githubusercontent.com/hetznercloud/hcloud-cloud-controller-manager/master/deploy/v1.2.0.yaml
License
Apache License, Version 2.0