paint-brush
Installing Configurator Using Helm Charts: Version Controls for Kubernetes ConfigMapsby@ashvinkumar
251 reads

Installing Configurator Using Helm Charts: Version Controls for Kubernetes ConfigMaps

by ashvinSeptember 14th, 2021
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

Configurator is an open-source project that version controls and keeps Kubernetes ConfigMaps and Secrets in sync with the deployments. The chart is qualified for helm version > v3 & Kube version v1.20.8.8. Make sure that a namespace 'configurator' already exists in your cluster. Add the configurator helm repository, by executing the command: *helm install <release_name> <repo_name/chart_name >.
featured image - Installing Configurator Using Helm Charts: Version Controls for Kubernetes ConfigMaps
ashvin HackerNoon profile picture


Configurator is an open-source project that version controls and keeps Kubernetes ConfigMaps and Secrets in sync with the deployments. Configurator uses CRDs to create CustomConfigMaps and CustomSecrets that in turn creates ConfigMaps and Secrets with a postfix. As and when a change is detected in a CustomConfigMap or a CustomSecret, Configurator automatically generates a new ConfigMap with a new postfix. This acts as a version controlling system for ConfigMaps. A change in a ConfigMap not only creates a new ConfigMap version but also rolls out a new deployment version across all the deployments using the ConfigMap. This enables both rolling update and rollback of ConfigMaps in sync with the deployment versions.


This blog will focus on the following motives:


  • Installing Configurator using the helm chart.

  • Customizing Configurator helm chart based on requirements.

  • Contributing back to the Configurator project.


System Requirements


Make sure that you have installed helm in your machine and you are connected to a Kubernetes cluster. The chart is qualified for helm version > v3 & Kube version v1.20.8. Follow the documentation from the link to install helm: https://helm.sh/docs/helm/helm_version/


helm version
version.BuildInfo{Version:"v3.0.2", GitCommit:"19e47ee3283ae98139d98460de796c1be1e3975f", GitTreeState:"clean", GoVersion:"go1.13.5"}


Installing Configurator using helm chart


Follow the below steps to directly deploy the Configurator helm package. Make sure that a namespace 'configurator' already exists in your cluster. If not, create a namespace with the following command.


kubectl create namespace configurator


Add the configurator helm repository, by executing the following command :


helm repo add gopaddle_configurator https://gopaddle-io.github.io/configurator/helm/


Once the command is executed, verify the repository by running the command below. You must see the configurator_helm repo in the list.


helm repo list


The output must be similar to this:


NAME             	      URL                                           
hashicorp        	      https://helm.releases.hashicorp.com              
gopaddle_configurator	  https://gopaddle-io.github.io/configurator/helm/


Once you've verified the repo, install the helm chart with the following command: helm install <release_name> <repo_name/chart_name>


helm install release1.0.0 gopaddle_configurator/configurator


This installs the Configurator CRDs and the controller in the 'configurator' namespace. After you install the helm chart, verify by listing the resources in the corresponding namespace using the following commands.


kubectl get pods -n configurator
kubectl get crds -n configurator
kubectl get serviceaccounts -n configurator
kubectl get clusterrolebindings -n configurator


Configurator is now ready for use.


Here is a reference blog on how to use configurator with the deployments: https://blog.gopaddle.io/2021/04/01/strange-things-you-never-knew-about-kubernetes-configmaps-on-day-one/


Customizing Configurator helm chart based on requirements


Sometimes, you may wish to change the Configurator image name, Docker repository, image tag or even include other service charts along with Configurator. Modifying the Configurator helm is pretty straightforward.

Make sure you've cloned the Configurator GitHub project before proceeding with the next steps.

To clone the project, run the following command:


git clone https://github.com/gopaddle-io/configurator.git


The helm package needs to be unpacked to modify the helm chart. The zip file will be present at the path configurator/helm in the Configurator project. Choose this option when you want to modify the helm chart configuration. Unzip the file with the following command.


tar -zxvf <path to .tgz file> 


This will extract the contents of the chart in a folder.

Once you extract, the helm chart's file system tree will look like this:


configurator
├── charts
├── Chart.yaml
├── crds
│   ├── crd-customConfigMap.yaml
│   └── crd-customSecret.yaml
├── templates
│   ├── configurator-clusterrolebinding.yaml
│   ├── configurator-clusterrole.yaml
│   ├── configurator-deployment.yaml
│   ├── configurator-serviceaccount.yaml
│   └── tests
└── values.yaml


The crds directory contains the custom resource definition files - crd-customConfigMap.yaml & crd-customSecret.yaml. The templates directory contains the resource's yaml files, in our case, it contains the roles and role bindings and the configurator service definitions. The charts directory is empty by default. This folder can be used to add your application charts that use Configurator Custom Resource. The Chart.yaml file contains information about the helm, like the chart's name, description, type etc.


# Default values for my_chart.
# This is a YAML-formatted file.
# Declare variables to be passed into your templates.

replicaCount: 1
replicas: 1
namespace: configurator
image: gopaddle/configurator:latest


You can edit the values.yaml file to your requirements like changing the namespace, replica_count or the image name, docker repository or the image tag. Make sure that the namespace used in the values.yaml exists in the cluster before you do a helm install.


Once the necessary configuration is done, execute the following command to install the charts into your cluster : helm install <release_name> <chart_name>


helm install release1.0.0 configurator


This will install the helm chart inside the cluster with the new configurations.


Contributing back to the configurator project


To contribute the helm changes back to the Configurator project, you need to package the helm chart with the following command :


helm package <path to helm chart>


This command will package the charts to a .tgz file. After packaging the helm, you need to give a pull request for code review & merge.


You can take a look at this open-source project @ https://github.com/gopaddle-io/configurator.git.

For any queries on how to use or how to contribute to the project, you can reach us on our discord server - https://discord.gg/dr24Z4BmP8


Image courtesy - https://www.freepik.com/vectors/technology

Technology vector created by stories - www.freepik.com


This article was also published here.