动态卷供应
上篇文章讲述的持久性存储,是先创建pv,然后才能创建pvc。如果不同的命名空间里同时要创建不同的pvc,那么就需要提前创建好pv,这样才能为pvc提供存储。但是这种方式太过繁琐,可以使用storageClass(简称cs)来解决该问题。使用cs时,管理员不需要提前创建pv,只要创建好storageClass之后就不需要管pv了,用户创建pvc的时候,storageClass会自动创建一个pv和这个pvc进行绑定。
定义storageClass必须使用分配器(provisioner),不同的provisioner可以使用不同的后端存储。有些分配器是kubernetes内置的,有些由第三方提供,通过自定义CSIDriver(容器存储接口驱动)来实现分配器。内置分配器名称前缀为 “kubernetes.io” 并打包在 Kubernetes 中。更详细内容参照:https://kubernetes.io/zh/docs/concepts/storage/storage-classes/
使用NFS创建动态卷供应——部署nfs分配器
- 克隆项目,默认命名空间namespace为default
yum install -y git
git clone https://github.com/kubernetes-incubator/external-storage.git
cd external-storage/nfs-client/deploy/
- 部署rbac权限
kubectl apply -f rbac.yaml
- 编辑
deployment.yaml
文件,修改NFS_SERVER和NFS_PATH为你的nfs服务器信息(两处都修改),命名空间和rbac.yaml一致,镜像下载策略也可设置。kubernetesv1.20之后版本需要修改/etc/kubernetes/manifests/kube-apiserver.yaml文件, command下增加一项配置:
- --feature-gates=RemoveSelfLink=false
然后重启所有节点kubelete
vi deployment.yaml
vi /etc/kubernetes/manifests/kube-apiserver.yaml
- 部署NFS分配器
kubectl apply -f deployment.yaml
kubectl get deployments.apps
kubectl get pod
使用NFS创建动态卷供应——部署storageClass
- 创建storageClass的yaml文件
storageClass_nfs.yaml
,这里provisioner值fuseim.pri/ifs是由deployment.yaml文件里指定的分配器的名字。创建的storageClass名字是managed-nfs-storage
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: managed-nfs-storage
provisioner: fuseim.pri/ifs
parameters:
archiveOnDelete: "false"
- 创建storageClass并查看
kubectl apply -f storageClass_nfs.yaml
kubectl get sc
使用NFS创建动态卷供应——使用动态卷创建一个pvc
- 创建yaml文件
pvc_sc.yaml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: pvc1
spec:
accessModes:
- ReadWriteMany
storageClassName: managed-nfs-storage
resources:
requests:
storage: 5Gi
- 创建pvc,并查看,STATUS为Bound即创建成功。
kubectl apply -f pvc_sc.yaml
kubectl get pvc
kubectl get pv
- 删除pvc,由于StorageClass默认RECLAIMPOLICY为DELETE,删除pvc时pv也被删除。
kubectl delete pvc pvc1