Kubermatic
Kubermatic in de.NBI cloud (Berlin)¶
At the de.NBI cloud site in Berlin we use Kubermatic as software to deploy "vanilla" kubernetes cluster into OpenStack projects. We will describe here, how you can use this. To gain access to Kubermatic you first need to apply for a OpenStack Project. Please state in the application that you want to use Kubernetes. After your project got approved you can access your resources at our Kubermatic login page: https://k.denbi.bihealth.org/
Contact us via mail in case you need further assistence: denbi-cloud@bih-charite.de
Get helm and kubectl going on the jumphost (with your user)¶
The configuration and cluster management via terminal commands is done from jumphost-01.denbi.bihealth.org. In order to configure the cluster you first need to setup the environment in the jumphost with your Elixir user. So connect to the jumphost via ssh. When the cluster is all setup you can download the configuration file from Kubermatic to actially connect to the cluster. We will come back to this later. For now issue the following commands in your home directory.
mkdir ~/.kube
## Later you will be copying your Kubeconfig from the Kubermatic UI to `~/.kube/config` in this folder
mkdir ~/bin
cd ~/bin
curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl
chmod +x ./kubectl
## https://github.com/helm/helm/releases
curl -s https://get.helm.sh/helm-v3.15.3-linux-amd64.tar.gz | tar xvz
mv linux-amd64/helm ~/bin
echo "export PATH=\$PATH:~/bin/" >> ~/.bashrc
## Install k9s as simple way to explore your cluster on the cli
curl -sS https://webinstall.dev/k9s | bash
How to create K8s Cluster with Kubermatic¶
In order to create a kubernetes cluster in your OpenStack project you need the application credentials from your project. If you not already created application credentials, please follow this guide to do so.
When you have the application credentials, it makes sense to upload a SSH key to your Kubermatic project. With that, you have the ability to access the K8s nodes created in a later step via ssh.
Continue to create your K8s cluster:
Select the cloudprovider (there is only OpenStack available):
You need to decide wether you will deploy your cluster only for internal use, or if you need to make services accasable from the internet. When you only whant to use the cluster internally choose 'Berlin' as datacenter (this should be the default) otherwise choose 'Berlin DMZ'. When using the cluter for external services you also need to apply for a public IP. Please do so by writing an email to us denbi-cloud@bih-charite.de.
Here you can configure your basic cluster settings, like name and version. For most setups this is sufficient. Note: you can always start with an "older K8s" version and issue an upgrade later. The default network provider for the cluster is cilium the CNI Plugin Version can be left unchanged.
In this window you configure the advanced settings. In the first place use Default
as the Domain, and type in the OpenStack application credentials , that you have created for your project.
Note: If you have access to multiple projects, you need to take care, that you are using the right credentials for the project that you select as "Project". Kubermatic will always display all projects that you can see, but the cluster will be spawned in the project that belongs to the application credentials (this is a OpenStack thing).
Use the corresponding floating ip pool, to your setup (if you have decided for DMZ earlier use dmz-ext
in all other cases use public2
).
You don't need to fill out the Advanced area (but you can if you want), Kubermatic will create everything needed.
Now you can create your first worker nodes. This is done with a machine deployment that you can configure (name, count of nodes (replicas), Image (we support ubuntu and CentOS) and flavor. If you are familiar with kubernetes and have specific needs for the nodes you can use custom images by uploading them to OpenStack. If not just keep the default entires here. Flavors and images can be looked up in your OpenStack project. You can also assign your workers floating ips, but you can also create a loadbalancer lateron.
You can install applications into the cluster in the next window. By default nothing is installed here, you can later install applications via helm charts.
The last step shows a summary window in that you can click on "create cluster" at the bottom right.
The controlplane of your cluster will now be created and you will see instances (workers) spawned in your OS project. After a few minutes it should look like the following.
Note: The creation of you cluster could take up to 20 Minutes due to internal processes.
You can access the K8s dashboard and download your kubeconfig with the buttons at the top right.
The kubeconfig file must be copied to the jumphost in order to use it to access the clutser from there. Copy the file to your home directory into ~/.kube/config
.
When all is setup you can ssh into jumphost-01.denbi.bihealth and use kubectl get all
to see all available resources in your cluster.
create ingress with traefik¶
- you have your kubeconfig
- helm and kubectl is installed on the jumphost
helm repo add traefik https://traefik.github.io/charts
helm repo update
helm install traefik traefik/traefik
This will create a loadbalancer in OpenStack and you can assign a floating IP to it. To allocate a floating IP, go to your OpenStack peject and go to Network → Loadbalancers and look for the loadbalancer with the cluster id from Kubermatic in the name. Click on the small arrow on the right and select Associate Floating IP. Select the Floating IP that was given to you when applying for a public IP.
All other cluster configurations must be done from jumphost-01.denbi.bihealth.org.