Skip to main content

Kubernetes Helm

Helm

Helm is a package manager for deploying applicatons.

Adding stable repository

helm repo add <alias> <helm repo>
helm repo add stable https://charts.helm.sh/stable

Search chart in a repo

helm search repo stable/mysql

Deploy application using helm

helm install <Name of the application> <repo/chart-name>
Eg: helm install mysql testing/mysql

Confirm current context

kubectl config current-context

Chart definition

helm show chart <repo/chartname>
helm show readme <repo/chartname>
helm show values <chart-name>

dry run

helm install <name-of -the-application> <chart name>  --dry-run --debug

Confirm deployment

helm list

List pods, services, deployments and replica sets

kubectl get all 

status of the release

helm status <app-deployed>
eg: helm status mysql
helm get manifest <chart-deployed>

View release hhistory

helm history mysql

Unistall a release

helm uninstall mysql --keep-history
helm delete mysql

Show all the version of a helm chart

helm search repo mysql --versions

Install specific version of the chart

helm install mysql daya/mysql --version <version>
eg: helm install mysql testing/mysql --version 1.16.3


Search all the versions for a specific chart

helm search repo "daya/mysql" --versions



Rolling upgrade

helm upgrade mysql daya/mysql --version <version>


helm history mysql
REVISION        UPDATED                         STATUS          CHART           APP VERSION     DESCRIPTION
1               Fri Jan  7 12:42:53 2022        superseded      mysql-1.6.3     5.7.28          Install complete
2               Fri Jan  7 17:50:08 2022        deployed        mysql-1.6.4     5.7.30          Upgrade complete


Rollback 

helm rollback mysql <revision number>

Pull down a chart 

helm pull stable/mysql --untar

Helm Chart Structure

Helm Repository:

Helm repo is any http server which stores tar files.

  1. https://artifacthub.io/
  2. https://hub.helm.sh

Creating helm chart

helm create <chart-name>

Create a simple deployment spec

helm create deployment nginx --image=nginx --dry-run=client --output=yaml

Package the chart

helm package <local location> --destination C:/Charts
















































Happy Learning😀

Comments

Popular posts from this blog

Kubernetes ETCDCTL

ETCD is a key-value data store for storing kubernetes state and objects. ETCDCTL is the tool used to back up with snapshot. ETCDCTL a command line tool for interacting with the etcd server  Key Features:  Keep the event history until compaction. access to old version of keys. user controlled key compaction. Support range query. pagination support with limit argument. support consistency guarantee across multiple queries. Replace TTL key with lease. Support watch feature. ETCDTOOL Installation: Build binary from source code  Download tool directly  Build binary from source code: Checkout the code repository git clone -b v3.4.16 https://github.com/etcd-io/etcd.git Change directory to etcd cd etcd Run build script ./build The binaries are under the bin directory. exportPATH="$PATH:`pwd`/bin" Check etcd version etcd --version Download ETCD tool directly: kubectl exec -it etcd-docker-desktop -n kube-system -- /bin/bash -c 'ETCDCTL_API=3 /usr/local/bin/etcd --version' | ...

PODS, SERVICES & DEPLOYMENTS

PODS Pod is a wrapper to container and it is the smallest deployable unit in Kubernetes. pod yaml configuration   Pod Useful Commands: $kubectl version --short Client Version: v1.22.4 Server Version: v1.22.4 $kubectl get svc NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)   AGE kubernetes   ClusterIP   10.96.0.1                    <none>           443/TCP   5d20h $kubectl get nodes NAME             STATUS   ROLES                       AGE     VERSION docker-desktop   Ready    control-plane,master   3d23h   v1.22.4 $kubectl cluster-info Kubernetes control plane is running at https://kubernetes.docker.internal:6443 Core...

Kubernetes - Architecture

  What is Kubernetes:      Kubernetes is an open source container orchestration system for automating application deployment,     scaling, self-healing, rolling update and roll back.   Architecture Diagram: Master Node / Control Plane components:     Kube API server     Scheduler     Controller Manager     etcd store 1. Kube API Server:  API server acts as a front-end to kubernetes cluster & exposes the kubernetes cluster API.  API server talks to worker nodes.  API server validates and configures data for the api objects which includes pods, service   replica-controllers, deployments etc.  Once request is validated, it stores the cluster data under etcd store. 2. Schedulers:   Scheduler assigns pods to nodes  Scheduler determines which nodes are free and can take a new load.   Scheduler also checks for constraints before placing the load on any nodes. 3. etcd...