Installing Helm

Prerequisites

  • Install the kubectl binary on your Ansible box
  • Install the UCP Client bundle for the admin user
  • Confirm that you can connect to the cluster by running a test command, for example, kubectl get nodes

Playbook

To run the playbook on your Ansible controller:

# cd ~/Docker-Synergy
# ansible-playbook -i hosts playbooks/install_helm.yml --vault-password-file .vault_pass

The playbook relies on the variable helm_version to determine the version of Helm to download. The playbooks have been tested using version 2.12.3. You must also specify the appropriate checksum for the download in the variable helm_checksum. This value can be obtained from the downloads page at https://github.com/helm/helm/releases. The vars.sample file that ships with this release contains the following values:

helm_version: "2.12.3" 
helm_checksum: "sha256:3425a1b37954dabdf2ba37d5d8a0bd24a225bb8454a06f12b115c55907809107"

Install sample charts

A number of sample charts are delivered with the solution, for the purposes of demonstration.

Alpine

A simple chart is provided in the ~/Docker-Synergy/test/files/helm/alpine directory to run a single pod of Alpine Linux.

The templates/ directory contains a very simple pod resource with a couple of parameters. The values.yaml file contains the default values for the alpine-pod.yaml template.

# cd ~/Docker-Synergy
# helm install test/files/helm/alpine

The output shows that a single pod was deployed.

NAME:   old-mole
LAST DEPLOYED: Fri Feb  8 17:27:35 2019
NAMESPACE: default
STATUS: DEPLOYED

RESOURCES:
==> v1/Pod
NAME             READY  STATUS   RESTARTS  AGE
old-mole-alpine  1/1    Running  0         0s

Nginx

An example chart is provided in the ~/Docker-Synergy/test/files/helm/nginx directory to install a simple nginx server according to the following pattern:

  • A ConfigMap is used to store the files the server will serve. (templates/configmap.yaml)
  • A Deployment is used to create a Replica Set of nginx pods. (templates/deployment.yaml)
  • A Service is used to create a gateway to the pods running in the replica set (templates/service.yaml)

The values.yaml exposes a few of the configuration options in the charts.

# cd ~/Docker-Synergy
# helm install test/files/helm/nginx

The output shows a service being created with a NodePort at 34567. This value comes from the values.yml file in the folder.

NAME:   worn-olm
LAST DEPLOYED: Fri Feb  8 16:23:21 2019
NAMESPACE: default
STATUS: DEPLOYED

RESOURCES:
==> v1/Deployment
NAME            DESIRED  CURRENT  UP-TO-DATE  AVAILABLE  AGE
worn-olm-nginx  1        1        1           1          14s

==> v1/Pod(related)
NAME                             READY  STATUS     RESTARTS  AGE
worn-olm-nginx-7d648f7dfb-gg2jk  1/1    Running    0         14s
worn-olm-nginx-vhwc7             0/1    Completed  0         14s

==> v1/ConfigMap
NAME            DATA  AGE
worn-olm-nginx  2     14s

==> v1/Service
NAME            TYPE      CLUSTER-IP    EXTERNAL-IP  PORT(S)       AGE
worn-olm-nginx  NodePort  10.96.30.222  <none>       80:34567/TCP  14s

Helm also allows you to easily delete installed releases. List the installed releases to find the name of the release you wish to delete.

# helm list
NAME            REVISION        UPDATED                         STATUS          CHART           APP VERSION     NAMESPACE
worn-olm        1               Fri Feb  8 16:23:21 2019        DEPLOYED        nginx-0.1.0                     default

Use the helm delete command to remove the named release.

# helm delete worn-olm
release "worn-olm" deleted