Using Helm Kubernetes Application Deployment


Helm Kubernetes is a powerful package manager for Kubernetes, designed to simplify the deployment and management of applications. This article will guide you through the basics of using Helm, its key features, and practical examples to help streamline your Kubernetes application deployment.

What is Helm Kubernetes?

Helm is a tool that helps you manage Kubernetes applications through Helm charts. Helm charts are collections of pre-configured Kubernetes resources that make it easy to deploy and manage complex applications. Helm significantly reduces the complexity of deploying and maintaining applications in Kubernetes clusters.

Key Features of Helm

  • Charts: Pre-packaged Kubernetes applications.
  • Releases: Installations of charts into a Kubernetes cluster.
  • Repositories: Locations where charts can be stored and shared.
  • Rollback: Ability to revert to previous versions of a chart.

Getting Started with Helm

To get started with Helm, you need to install it on your local machine and configure it to work with your Kubernetes cluster.

Installing Helm

Download and Install Helm:

  • For macOS:
    bash brew install helm
  • For Linux:
    bash curl | bash

Verify the Installation:

   helm version

Adding a Helm Repository

Helm repositories are locations where charts are stored. To use Helm, you need to add a repository:

helm repo add stable
helm repo update

Installing a Helm Chart

Once you’ve added a repository, you can install a chart from it. For example, to install the Nginx chart:

helm install my-nginx stable/nginx-ingress

This command installs the Nginx Ingress controller with the release name my-nginx.

Managing Helm Releases

Helm releases represent instances of charts running in your Kubernetes cluster. You can manage these releases with various Helm commands.

Listing Helm Releases

To list all the releases in your cluster:

helm list

Upgrading a Helm Release

To upgrade a release with a new version of the chart or new configuration values:

helm upgrade my-nginx stable/nginx-ingress --set controller.replicaCount=2

Rolling Back a Helm Release

If an upgrade causes issues, you can roll back to a previous release:

helm rollback my-nginx 1

This command rolls back the my-nginx release to revision 1.

Creating Custom Helm Charts

Helm allows you to create your own custom charts to package and deploy your applications.

Creating a New Chart

To create a new chart:

helm create my-chart

This command creates a new directory structure for your chart with default templates and values.

Modifying Chart Templates

Modify the templates and values in the my-chart directory to fit your application’s requirements. Templates are located in the templates/ directory, and default values are in the values.yaml file.

Installing Your Custom Chart

To install your custom chart:

helm install my-release ./my-chart

This command deploys your chart with the release name my-release.

Best Practices for Using Helm

  • Version Control: Store your Helm charts in version control to track changes and collaborate with others.
  • Use Values Files: Customize deployments by using values files to override default values.
  • Chart Testing: Test your charts in a staging environment before deploying to production.
  • Documentation: Document your charts and configurations to ensure maintainability.


Helm is an invaluable tool for managing Kubernetes applications, offering powerful features to simplify deployment, management, and versioning. By using Helm, you can streamline your Kubernetes workflows, reduce complexity, and ensure your applications are deployed consistently and reliably. Embrace Helm to enhance your Kubernetes deployments and maintain a robust and efficient infrastructure. Thank you for reading the DevopsRoles page!


About HuuPV

My name is Huu. I love technology, especially Devops Skill such as Docker, vagrant, git, and so forth. I like open-sources, so I created to share the knowledge I have acquired. My Job: IT system administrator. Hobbies: summoners war game, gossip.
View all posts by HuuPV →

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.