卷属性类

特性状态: Kubernetes v1.29 [alpha]

本页面假设您熟悉 Kubernetes 中的 StorageClassPersistentVolume

VolumeAttributesClass 为管理员提供了一种描述其提供的可变存储“类”的方法。不同的类可能映射到不同的服务质量级别。Kubernetes 本身对这些类的表示没有任何倾向性。

这是一项 alpha 特性,默认情况下处于禁用状态。

如果您想在 alpha 阶段测试该特性,则需要为 kube-controller-manager 和 kube-apiserver 启用 VolumeAttributesClass 特性门控。您可以使用 --feature-gates 命令行参数

--feature-gates="...,VolumeAttributesClass=true"

您也只能将 VolumeAttributesClass 与由 容器存储接口 支持的存储一起使用,并且仅限于相关的 CSI 驱动程序实现 ModifyVolume API 的情况下。

VolumeAttributesClass API

每个 VolumeAttributesClass 都包含 driverNameparameters,它们在需要动态配置或修改属于该类的 PersistentVolume (PV) 时使用。

VolumeAttributesClass 对象的名称很重要,它是用户请求特定类的方式。管理员在首次创建 VolumeAttributesClass 对象时设置类的名称和其他参数。虽然 PersistentVolumeClaim 中 VolumeAttributesClass 对象的名称是可变的,但现有类中的参数是不可变的。

apiVersion: storage.k8s.io/v1alpha1
kind: VolumeAttributesClass
metadata:
  name: silver
driverName: pd.csi.storage.gke.io
parameters:
  provisioned-iops: "3000"
  provisioned-throughput: "50" 

配置器

每个 VolumeAttributesClass 都有一个配置器,用于确定哪个卷插件用于配置 PV。必须指定字段 driverName

VolumeAttributesClass 的特性支持在 kubernetes-csi/external-provisioner 中实现。

您不限于指定 kubernetes-csi/external-provisioner。您还可以运行和指定外部配置器,它们是遵循 Kubernetes 定义的规范的独立程序。外部配置器的作者可以完全决定其代码所在的位置、配置器的交付方式、运行方式、使用的卷插件等。

调整器

每个 VolumeAttributesClass 都有一个调整器,用于确定哪个卷插件用于修改 PV。必须指定字段 driverName

VolumeAttributesClass 的修改卷特性支持在 kubernetes-csi/external-resizer 中实现。

例如,现有的 PersistentVolumeClaim 正在使用名为 silver 的 VolumeAttributesClass

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: test-pv-claim
spec:
  
  volumeAttributesClassName: silver
  

集群中提供了一个新的 VolumeAttributesClass gold

apiVersion: storage.k8s.io/v1alpha1
kind: VolumeAttributesClass
metadata:
  name: gold
driverName: pd.csi.storage.gke.io
parameters:
  iops: "4000"
  throughput: "60"

最终用户可以使用新的 VolumeAttributesClass gold 更新 PVC 并应用

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: test-pv-claim
spec:
  
  volumeAttributesClassName: gold
  

参数

VolumeAttributeClass 具有描述属于它们的卷的参数。根据配置器或调整器的不同,可以接受不同的参数。例如,参数 iops 的值 4000 和参数 throughput 特定于 GCE PD。省略参数时,将在卷配置时使用默认值。如果用户使用省略参数的不同 VolumeAttributesClass 应用 PVC,则可能会使用参数的默认值,具体取决于 CSI 驱动程序的实现。有关更多详细信息,请参阅相关的 CSI 驱动程序文档。

为 VolumeAttributesClass 最多可以定义 512 个参数。参数对象的总长度(包括其键和值)不能超过 256 KiB。

上次修改时间:2023 年 11 月 28 日太平洋标准时间上午 9:04:根据评论更新 - 11 月 28 日 (058e522b63)