阿里云容器服务CSI支持对NAS卷的子目录进行配额限制。通过配额限制确保您在资源分配的基础上,提升整体资源的利用率。本文介绍如何对NAS卷子目录进行配额限制,以及如何手动触发扩容NAS存储卷。
前提条件
csi-plugin的镜像版本不低于v1.18.8.45。关于csi-plugin的版本说明,请参见csi-plugin。
NAS卷需要使用子目录进行挂载。
背景信息
关于NAS卷的管理配额,请参见目录配额。
使用限制
目前仅容量型NAS支持使用配额限制,其他NAS类型均不支持。关于NAS卷的规格类型,请参见NAS规格类型。
仅支持子目录挂载方式设置配额。
对于单个文件系统,最多允许对500个目录设置配额。
设置限制性配额后,如果文件使用量超过限制会导致增加文件长度,创建文件、目录和特殊文件,移动文件到目录等写入操作失败,应用层会收到IOError。
由于限制型配额的高风险性,强烈建议您在业务关键路径上谨慎评估和测试验证后,再配置限制型配额。
NAS配额的设置为异步执行,因此限制型配额的生效和失效都有延迟,正常情况需要等待5~15分钟。
使用示例
使用以下YAML内容,创建带有配额子目录NAS的StorageClass,并开启允许扩容策略。
apiVersion: storage.k8s.io/v1 kind: StorageClass metadata: name: alicloud-nas-quota-sc mountOptions: - nolock,tcp,noresvport - vers=3 parameters: volumeAs: subpath server: "xxx.cn-hangzhou.nas.aliyuncs.com:/" archiveOnDelete: "false" path: "/abc" volumeCapacity: "true" # 创建动态卷带有配额能力。 provisioner: nasplugin.csi.alibabacloud.com reclaimPolicy: Delete allowVolumeExpansion: true # 开启允许动态卷扩容能力。
参数
描述
mountOptions
挂载NAS的options参数在mountOptions中配置,包括NFS协议版本。
volumeAs
可选subpath、filesystem,分别表示创建子目录类型的PV和文件系统类型PV。
server
表示创建子目录类型的PV时,NAS文件系统的挂载点地址。
archiveOnDelete
表示在reclaimPolicy为Delete时,是否删除后端存储。因为NAS为共享存储,添加此选项进行双重确认。默认为true。
path
表示挂载子目录,极速NAS需要以/share开头。
volumeCapacity
表示是否使用配额。可选值为:true,false。
provisioner
表示ACK动态卷控制器名称。
reclaimPolicy
表示PV的回收策略。可选值为:
Retain:保留后端存储,删除PV及PVC不会删除对应的后端存储,例如云盘。
Delete:当删除PVC时,自动删除PV和后端的存储。
allowVolumeExpansion
表示是否支持NAS存储卷的扩容。
说明创建带有配额子目录NAS的StorageClass,需要将volumeCapacity设置为true。
使用以下YAML内容,创建Statefulset,包含容量大小为20 GiB的PVC。
apiVersion: apps/v1 kind: StatefulSet metadata: name: nas-sts spec: selector: matchLabels: app: busybox serviceName: "busybox" replicas: 1 template: metadata: labels: app: busybox spec: containers: - name: busybox image: busybox command: - sleep - "3600" volumeMounts: - name: nas-pvc mountPath: /data volumeClaimTemplates: - metadata: name: nas-pvc spec: accessModes: [ "ReadWriteMany" ] storageClassName: "alicloud-nas-quota-sc" resources: requests: storage: 20Gi
结果验证
- 本页导读 (1)