Kubernetes Dashboard Helm installation and configuration

 

Many are starting their journey working with Kubernetes aside from myself. I have been playing around a lot with Kubernetes in the home lab and elsewhere and getting up to speed on various technologies and solutions associated with Kubernetes. In my Kubernetes Home Lab Setup Step-by-Step post, I took a look at the step-by-step approach to getting a Kubernetes cluster up and running in the home lab. One of the first things you will want to do after installing and provisioning your Kubernetes cluster and cluster nodes is getting the Kubernetes Dashboard running. In this post, we will kill two birds with one stone and look at Kubernetes dashboard helm installation and configuration to see how you can install the Kubernetes Dashboard using helm.

What is Kubernetes Helm?

If you begin working with Kubernetes, you will no doubt see something referenced called helm. What is helm? The easiest way to think of helm is it is a package manager for Kubernetes clusters. Much like you use Linux repos to install software on your favorite Linux distro, you use the helm tool to go out and pull down applications to install in your Kubernetes cluster.

Helm allows you to install and manage Kubernetes applications. It does this by what it calls charts. What are charts? The chart is a bundle of information necessary to create an instance of a Kubernetes application.

In addition to the chart, there are a couple of other important concepts:

  • config – contains configuration information that can be merged into a packaged chart to create a releasable object.
  • release – a running instance of a chart, combined with a specific config

Using helm charts, you can carry out the following tasks: 

Create new charts from scratch

  • Package charts into chart archive (tgz) files
  • Interact with chart repositories where charts are stored
  • Install and uninstall charts into an existing Kubernetes cluster
  • Manage the release cycle of charts that have been installed with Helm

Installing Helm

The process to install helm is very easy. Just run the following three commands in your favorite Linux distro and you will be able to pull down the helm tool in no time.

curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3

chmod 700 get_helm.sh

./get_helm.sh

Kubernetes Dashboard Helm installation and configuration

Now that we have the helm utility downloaded and installed, we can use it to easily install the Kubernetes dashboard. Just a little learning that I have done recently, Helm v3 has departed from the previous stable repos that were used. While you can still access the stable repos, the best way to find the up-to-date applications you are looking for is in the hub. You can search both to see if the app you are looking for is in one or the other. As you can see below, the artifacthub site has the recent version of the Kubernetes dashboard.

Searching the stable repository and the hub using helm for kubernetes dashboard
Searching the stable repository and the hub using helm for kubernetes dashboard
One downside I found is that you can’t pull from the URL listed in the search return unless I am missing something here with the artifact hub. Instead, what I did was browse out to the artifact hub and load the repo presented from here and then installed from the official repo that was added after walking through the artifact hub site.

Browsing to the artifact hub site adding the repo and then pulling the install from the repoBrowsing to the artifact hub site adding the repo and then pulling the install from the repo

As you can see above in the official chart found in the hub, you need to run the following two commands:
helm repo add kubernetes-dashboard https://kubernetes.github.io/dashboard/
helm install <your dashboard name> kubernetes-dashboard/kubernetes-dashboard

After the installation is successful, it will direct you below the installation of the application to enable port forwarding to access. However, I will be changing this to NodePort and accessing the application that way for lab purposes.

Installing the official kubernetes dashboard using the helm chart
                    Installing the official kubernetes dashboard using the helm chart

Below, I am changing the service to NodePort instead of the ClusterIP. To do that, you can run the following command, replacing the service with your service name:

kubectl edit svc k8s-dashboard-kubernetes-dashboard
Configuring the kubernetes dashboard service for nodeport access
                        Configuring the kubernetes dashboard service for nodeport access

Logging into the Kubernetes Dashboard

The next hurdle is actually logging into the Kubernetes Dashboard. How do you do this? You have a couple of ways, using a token or kubectl config. Let’s look at using a token.

Logging in with a token
                        Logging in with a token

How do you find the token for logging in? Use the commands below to get the token that is installed by default with the installation of the dashboard using helm.

kubectl get sa
kubectl describe sa k8s-dashboard-kubernetes-dashboard
Copy the Token value listed
kubectl describe secret <token value copied>
Getting the service account token and secret values for logging into the kubernetes dashboard
            Getting the service account token and secret values for logging into the kubernetes dashboard

However, you will probably get the following error

Permissions errors logging in with the default token generated by the helm install
                        Permissions errors logging in with the default token generated by the helm install
Create a service account with the cluster admin role. I highly recommend visiting the Github site of “justmeandopensource.” Download the sa_cluster_admin.yaml. This creates a service account with the cluster admin role using the following code:

apiVersion: v1
kind: ServiceAccount
metadata:
  name: dashboard-admin
  namespace: kube-system
---
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
  name: cluster-admin-rolebinding
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: cluster-admin
subjects:
- kind: ServiceAccount
  name: dashboard-admin
  namespace: kube-system
To install the new service in your Kubernetes cluster, run the following command to install the yaml file:
kubectl create -f sa_cluster_admin.yaml

After creating the new service account, you can check the service accounts by running:

kubectl -n kube-system get sa

You will see the service account dashboard-admin. Now, we go through the same process to get the token and secret values for the new service account.

kubectl -n kube-system describe sa dashboard-admin
Copy the Token value
kubectl -n kube-system describe secret <token value>
Getting the newly created cluster admin service account and token
            Getting the newly created cluster admin service account and token
Getting the token secret value for logging into the kubernetes dashboard with full privileges
    Getting the token secret value for logging into the kubernetes dashboard with full privileges
Now, after logging into the Kubernetes Dashboard with the new cluster admin service account, there are no permissions issues and all dashboard elements are displaying correctly.
After logging into the kubernetes dashboard with the cluster admin service account
        After logging into the kubernetes dashboard with the cluster admin service account

Wrapping Up

Hopefully this Kubernetes Dashboard Helm installation and configuration guide will help any who may be struggling to install the Kubernetes dashboard application in their Kubernetes cluster. Using helm is a great way to easily install applications into your cluster using the charts methodology.

Post a Comment

0 Comments