Volume Provisioning
The first thing to make use of storage is to provision the volumes. And one might need to provision more than one volumes to fit different use cases. In K8S, there two ways to get a volume provisioned: Static provisioning and Dynamic provisioning.
Static provisioning
Provision the storage manually by following the instruction from the storage vendor.
If you are using VMware vSphere, you could create VMDK on your vSan datastore
Next step is to create the PV which consumes the storage you just created.
storageClass: demo
is used to bind PVC to this PV. You could have no such StorageClass created before hand.
vsphereVolume
is the in-tree volume plugin supported by K8S. More details could be found here
Next step is to create PVC which could consume PV for a pod.
If the storageClassName does not match the one you used for PV, your PVC will not bind to the PV you just created.
Use it in Pod or Deployment. The following YAML is just an example for Pod.
Follow the tutorial here if you would like to use minikube to do some experiments.
Above is the steps you would use to manually provision a storage/volume.
Dynamic provisioning
Why dynamic provision
Before dynamic provisioning, cluster administrators had to manually make calls to their cloud or storage provider to provision new storage volumes, and then create PersistentVolume objects to represent them in Kubernetes. With dynamic provisioning, these two steps are automated, eliminating the need for cluster administrators to pre-provision storage. Instead, the storage resources can be dynamically provisioned using the provisioner specified by the StorageClass object.
Better resource management ?
End to end workflow (Bottom up)
Create
StorageClass
The provisioner
specifies what volume plugin to be used for dynamic provisioning. The volume plugin is in charge of create and setup the VMDK in the vSphere example, and also create the PV automatically. Differnt vendor has different implementations.
The provisioner has
kubernetes.io
as prefix is the in-tree volume plugin. Its implementation could be found atkubernetes/pkg/volume/vsphere_volume/vsphere_volume.go
fromhttps://github.com/kubernetes/kubernetes.git
The provisioner used above is the in-tree provisioner, more about provisioner for the external storage provisioner could be found here.
What is CSI could be found here.
Create PVC
Once the PVC is created, it will find the storageclass for dynamic provisioning. The storageClassName must match the StorageClass created in step #1.
The design of volume provisioning could be found here.
Pod or Deployment uses the PVC
Other references:
Last updated