Skip to content

Latest commit

 

History

History
185 lines (142 loc) · 16.4 KB

File metadata and controls

185 lines (142 loc) · 16.4 KB

Install local-volume-provisioner with helm

Here is a helm chart for local-volume-provisioner. You can easily generate yaml files with helm template or install local-volume-provisioner in your Kubernetes with helm install directly.

Table of Contents

Install Helm

Please follow official instructions to install helm.

Customize your deployment with values file

Our chart provides a variety of options to configure deployment, see provisioner/values.yaml.

And there are a lot of examples to help you get started quickly.

Install local-volume-provisioner

Generate yaml files with helm template and install with kubectl

Helm templating is used to generate the provisioner's DaemonSet, ConfigMap and other necessary objects' specs. The generated specs can be further customized as needed (usually not necessary), and then deployed using kubectl.

Here is basic workflow:

Install using helm repo

Install by adding the repo as a Helm repo:

helm repo add sig-storage-local-static-provisioner https://kubernetes-sigs.github.io/sig-storage-local-static-provisioner
helm template --debug sig-storage-local-static-provisioner/local-static-provisioner --version <version> --namespace <namespace> > local-volume-provisioner.generated.yaml
# edit local-volume-provisioner.generated.yaml if necessary
kubectl create -f local-volume-provisioner.generated.yaml

Or install by cloning the repo locally:

git clone --depth=1 https://github.com/kubernetes-sigs/sig-storage-local-static-provisioner.git
helm template -f <path-to-your-values-file> <release-name> --namespace <namespace> ./helm/provisioner > local-volume-provisioner.generated.yaml
# edit local-volume-provisioner.generated.yaml if necessary
kubectl create -f local-volume-provisioner.generated.yaml

Delete:

kubectl delete -f local-volume-provisioner.generated.yaml

Upgrade:

Update your custom values to match the new chart parameter

# Teardown the old provisioner
kubectl delete -f local-volume-provisioner.generated.yaml

# Update your custom values to match the new chart parameter

# Apply the new generated.yaml
kubectl create -f local-volume-provisioner.generated.yaml

Install with helm install directly

Helm provides an easy interface to install applications and sources into Kubernetes cluster. You can install local-volume-provisioner with helm install command directly. Here is basic workflow:

Install:

helm install -f <path-to-your-values-file> <release-name> --namespace <namespace> ./helm/provisioner

Note: set your preferred namespace and release name, e.g. helm install -f helm/examples/gke.yaml local-volume-provisioner --namespace kube-system ./helm/provisioner

Delete:

helm uninstall <release-name> --namespace

Upgrade: This action will recreate the running pod

Update your custom values to match the new chart parameter

helm upgrade --reset-value -f <path-to-your-values-file> <release-name> --namespace <namespace> ./helm/provisioner

--reset-values will reset custom values to the values from the new chart version. -f apply the custom values file on top.

Please refer helm docs for more information.

Configurations

The following table lists the configurable parameters of the local volume provisioner chart and their default values.

Parameter Description Type Default
nameOverride Override default chartname str ""
fullnameOverride Override default releasename str ""
rbac.create if true, create and use RBAC resources bool true
serviceAccount.create if true, create serviceaccount in .Release.Namespace bool true
serviceAccount.name if set serviceaccount if the given name will be created str ""
useJobForCleaning If set to true, provisioner will use jobs-based block cleaning. bool false
useNodeNameOnly If set to true, provisioner name will only use Node.Name and not Node.UID. bool false
minResyncPeriod Resync period in reflectors will be random between minResyncPeriod and 2*minResyncPeriod. str 5m0s
setPVOwnerRef If set to true, PVs are set to be dependents of the owner Node. bool false
additionalVolumes Additional volumes to create, for the default container and init containers to consume. list -
mountDevVolume If set to false, the node's /dev path will not be mounted into containers. bool true
additionalVolumeMounts Additional volumes to mount to the default container, the volumes should either be host paths or defined by additionalVolumes. list -
labelsForPV Map of label key-value pairs to apply to the PVs created by the provisioner. map -
enableWindows If true, Windows DaemonSet will be created by the provisioner. bool false
classes.[n].name StorageClass name. str -
classes.[n].hostDir Path on the host where local volumes of this storage class are mounted under. str -
classes.[n].mountDir Optionally specify mount path of local volumes. By default, we use same path as hostDir in container. str -
classes.[n].blockCleanerCommand List of command and arguments of block cleaner command. list -
classes.[n].volumeMode Optionally specify volume mode of created PersistentVolume object. By default, we use Filesystem. str -
classes.[n].fsType Filesystem type to mount. Only applies when source is block while volume mode is Filesystem. str -
classes.[n].namePattern File name pattern to discover. By default, discover all file names. str *
classes.[n].storageClass Create storage class for this class and configure it optionally. bool/map false
classes.[n].storageClass.reclaimPolicy Specify reclaimPolicy of storage class, available: Delete/Retain. str Delete
classes.[n].storageClass.isDefaultClass Set storage class as default bool false
classes.[n].storageClass.provisioner Specify provisioner of storage class. str kubernetes.io/no-provisioner
podAnnotations Annotations for each Pod in the DaemonSet. map -
podLabels Labels for each Pod in the DaemonSet. map -
hostPID Host PID set in the linux daemonset container spec. When set to true allows a pod to have access to the host process ID namespace bool false
image Provisioner image. str registry.k8s.io/sig-storage/local-volume-provisioner:v2.7.0
imagePullPolicy Provisioner DaemonSet image pull policy. str -
imagePullSecrets Provisioner image pull secrets. list -
priorityClassName Provisioner DaemonSet Pod Priority Class name. str ``
kubeConfigEnv Specify the location of kubernetes config file. str -
nodeLabels List of node labels to be copied to the PVs created by the provisioner. list -
nodeSelector NodeSelector constraint on nodes eligible to run the provisioner. map -
tolerations List of tolerations to be applied to the Provisioner DaemonSet. list -
resources Map of resource request and limits to be applied to the Provisioner Daemonset. map -
affinity List of affinity to be applied to the provisioner Daemonset. list -
privileged If set to false, containers created by the Provisioner Daemonset will run without extra privileges. bool true
initContainers Init containers. list -
serviceMonitor.enabled If set to true, Prometheus servicemonitor will be applied bool false
serviceMonitor.interval Interval at which Prometheus scrapes the provisioner str 10s
serviceMonitor.namespace The namespace Prometheus servicemonitor will be installed str .Release.Namespace
serviceMonitor.additionalLabels Additional labels for the servicemonitor map -
serviceMonitor.relabelings Additional metrics relabel_config lists -

Note: classes is a list of objects, you can specify one or more classes.

Examples

Here are a list of examples for various environments: