HostPath 是一种持久化存储,但 HostPath 内容是存储在节点上,导致只适合读取。
如果要求 Pod 重新调度后仍然能使用之前读写过的数据,就只能使用网络存储了,网络存储种类非常多,且有不同的使用方法,常见公有云提供商有块存储、文件存储、对象存储三种。
K8s 解决这个问题的方式是抽象了PV 和 PVC 来解耦这个问题,从而让使用者不用关心具体的基础设施,当需要存储资源的时候,只要像 CPU 和内存一样,声明要多少即可。
-
PV:描述是持久化存储卷,主要定义的是一个持久化存储在宿主机上的目录,比如一个 NFS 的挂载目录。
-
PVC:描述是 Pod 所希望使用的持久化存储的属性,比如,Volume 存储的大小、可读写权限等等。
CSI
$kubectlgetpo--namespace=kube-systemNAMEREADYSTATUSRESTARTSAGEeverest-csi-controller-6d796fb9c5-v22df2/2Running09m11severest-csi-driver-snzrr1/1Running012meverest-csi-driver-ttj281/1Running012meverest-csi-driver-wtrk61/1Running012m
PV
来看一下 PV 如何描述持久化存储,如创建了一个文件存储,这个文件存储 ID 为 68e4a4fd-d759-444b-8265-20dc66c8c502 ,挂载地址为 nas01-mycloud.com:/share-96314776。如果想在k8s中使用这个文件存储,则需要先创建一个PV来描述这个存储,如下所示。
apiVersion:v1kind:PersistentVolumemetadata:name:pv-examplespec:accessModes:-ReadWriteMany#读写模式capacity:storage:10Gi#定义PV的大小csi:driver:nas.csi.everest.io#声明使用的驱动fsType:nfs#存储类型volumeAttributes:everest.io/share-export-location:nas01-mycloud.com:/share-96314776#挂载地址volumeHandle:68e4a4fd-d759-444b-8265-20dc66c8c502
$ kubectl create -f pv.yaml
persistentvolume/pv-example created
$ kubectl get pv
NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE
pv-example 10Gi RWX Retain Available
PVC
PVC 可以绑定一个 PV,示例如下。
apiVersion:v1kind:PersistentVolumeClaimmetadata:name:pvc-examplespec:accessModes:-ReadWriteManyresources:requests:storage:10Gi#声明存储的大小volumeName:pv-example#PV的名称
创建PVC并查看。
$ kubectl create -f pvc.yaml
persistentvolumeclaim/pvc-example created
$ kubectl get pvc
NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE
pvc-example Bound pv-example 10Gi RWX
$kubectlgetpvNAMECAPACITYACCESSMODESRECLAIMPOLICYSTATUSCLAIMSTORAGECLASSREASONAGEpv-example10GiRWXRetainBounddefault/pvc-
来源:本文转自“运维小白之路”。