Kustomize, just like the name implies, is used for customizing Kubernetes deployments to help developers manage Kubernetes application configurations. With Kustomize, it is easy to define a base set of Kubernetes resources and create overlays on top of it in separate directories to modify or extend the base configuration. It allows you to have a single source of truth for all your Kubernetes application configuration while still being able to customize it for different environments or use cases. Kustomize is especially helpful while managing large or complex Kubernetes deployments, where maintaining separate YAML files for each environment or use case can be tricky and error-prone.
Using a rolling update strategy, this Kustomize tutorial will deploy multiple variants of a simple public Hello World server. So let's begin the show!!!
Prerequisites:
- Free Harness account with free builds
- Minikube to have a single node cluster access
- A repo containing the kustomization yaml file. We'll use a publicly available hellword kustomization cloned from Kustomize.
Tutorial
In our example repo, you can see the configMap.yaml
, deployment.yaml
, service.yaml
and kustomization.yaml
.
For any Kubernetes application deployment, we need deployment and service manifest files. In this tutorial, we are more interested in the kustomization manifest file. Why?
Let's take a use case where kustomization comes in handy for developers and DevOps professionals.
Suppose you're using a deployment package from a specific vendor that is almost suitable for your use case, but not entirely. Consequently, you create a fork of the deployment package, make necessary configuration changes, and apply it to your Kubernetes cluster. After a few months, the vendor releases a new version of the package that incorporates critical features that you require. To utilize those new features, you have to fork the updated package and reapply your configuration changes.
As your deployment scales, this repetitive process of reforking and customizing the deployment package can become a tedious task and lead to an increased likelihood of misconfigurations, which could compromise the stability of your product and services. This can be easily avoided by making use of kustomize.
Let's get back to our tutorial
Below is the kustomization.yaml
file in our example repo, an example of how to use Kustomize to manage a Kubernetes deployment for a web server application called hello.
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
# metadata:
# name: arbitrary
# Example configuration for the webserver
# at https://github.com/monopole/hello
commonLabels:
app: hello
resources:
- deployment.yaml
- service.yaml
- configMap.yaml
Here is a breakdown of its contents:
- apiVersion: kustomize.config.k8s.io/v1beta1: This specifies the version of the Kustomize configuration format being used.
- kind: Kustomization: This indicates that this is a Kustomize configuration file.
- commonLabels: This is a section where you can define common labels that will be applied to all resources in this Kustomize configuration. In this case, it defines a label named app with a value of hello.
- resources: This section lists the Kubernetes resources that should be managed by Kustomize. In this example, there are three resources: deployment.yaml, service.yaml, and configMap.yaml. These files are expected to be in the same directory as the kustomization.yaml file.
By default, Kustomize concatenates all the resources listed in the resources section in the order they appear and applies any overlays if they are specified.
This is just a basic example of a kustomization.yaml
file. You can add many more options and customizations to manage more complex deployments with multiple environments and configurations using Kustomize.
Login to your Harness CD module and start your free plan where you get free builds.
Go to the pipeline studio and create a new pipeline.
Add 'Kubernetes' as the deployment type.
Create a new service. Name the service as 'nginx'.
Select kustomize while adding the manifest details.
Add the manifest details stored in your GitHub repo.
This is the GitHub repo url - https://github.com/wings-software/harness-docs.git
Add your GitHub username and password (add password through a secret manager), as shown below.
Connect these details with a Harness Delegate.
You need to have a Delegate up and running to deploy with Harness. Let's add Delegate.
So, what is Harness Delegate?
A Delegate is a service that runs on your infrastructure to execute tasks on behalf of the Harness platform.
Now, you need to install this Harness Delegate on your Kubernetes cluster.
Make sure you have a cluster access from any cloud provider.
Nothing to worry about if you don't have access to any cluster access. We will make use of Minikube.
Install Minikube on your local machine.
Once the installation is complete, start the Minikube cluster with the following command.
minikube start
Get on to install a delegate.
There are many ways to install a delegate. You can choose whatever you are okay with. We choose 'Kubernetes' and 'Kubernetes manifest' from the options available.
As guided there, download the harness delegate yml file and run the below command from the folder where your yaml file is downloaded.
kubectl apply -f harness-delegate.yaml
Make sure to verify if the delegate installation is successful.
Once the delegate is installed. Connect it with your manifest details and make sure the connection is successful.
Next, create an environment and infrastructure as shown below.
Finally, in the execution step, select the rolling deployment strategy.
Apply changes, save and run the pipeline. You should see a successful execution of the pipeline.
You can see the console view also.
This is how you can deploy multiple variants of a simple public Hello World server using a rolling update strategy using Harness.
For more help, refer to the following Harness developer hub link.
Also, if you like to learn more about CI/CD and practical examples, follow my tutorial where I shared a complete CI/CD setup from scratch.
Top comments (0)