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.
Please follow official
instructions to install helm
.
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.
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 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
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.
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.
Here are a list of examples for various environments:
- examples/baremetal-cleanbyjobs.yaml
- examples/baremetal-resyncperiod.yaml
- examples/baremetal-tolerations.yaml
- examples/baremetal-provisioner.yaml
- examples/baremetal-with-resource-limits.yaml
- examples/baremetal-without-rbac.yaml
- examples/baremetal.yaml
- examples/gce-pre1.9.yaml
- examples/gce-retain.yaml
- examples/gce.yaml
- examples/gke.yaml
- examples/eks-nvme-ssd.yaml
- more...