赞
踩
为什么要改变默认存储类?
取决于安装模式,你的 Kubernetes 集群可能和一个被标记为默认的已有 StorageClass 一起部署。 这个默认的 StorageClass 以后将被用于动态的为没有特定存储类需求的 PersistentVolumeClaims 配置存储。更多细节请查看 PersistentVolumeClaim 文档。
storageClassName
的 PVC 都只能绑定到隶属于默认存储类的 PV 卷。 设置默认 StorageClass 的工作是通过将对应 StorageClass 对象的注解 storageclass.kubernetes.io/is-default-class
赋值为 true
来完成的。 如果管理员未设置默认存储类,集群对 PVC 创建的处理方式与未启用准入控制器插件时相同。 如果设定的默认存储类不止一个,当 PVC 被动态制备时将使用最新的默认存储类。storageClassName
设为 ""
的 PVC 只能被绑定到也将 storageClassName
设为 ""
的 PV。 不过,只要默认的 StorageClass 可用,就可以稍后更新缺少 storageClassName
的 PVC。 如果这个 PVC 更新了,它将不再绑定到也将 storageClassName
设为 ""
的 PV。预先安装的默认 StorageClass 可能不能很好的适应你期望的工作负载;例如,它配置的存储可能太过昂贵。 如果是这样的话,你可以改变默认 StorageClass,或者完全禁用它以防止动态配置存储。
删除默认 StorageClass 可能行不通,因为它可能会被你集群中的扩展管理器自动重建。 请查阅你的安装文档中关于扩展管理器的细节,以及如何禁用单个扩展
改变默认 StorageClass
- kubectl patch storageclass xxxxxx -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'
-
- kubectl patch storageclass storageclass-name -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'
注意:最多只能有一个 StorageClass 能够被标记为默认。 如果它们中有两个或多个被标记为默认,Kubernetes 将忽略这个注解, 也就是它将表现为没有默认 StorageClass。
- [root@haiouc ~]# k get storageclass rbd -o yaml
- apiVersion: storage.k8s.io/v1
- kind: StorageClass
- metadata:
- annotations:
- meta.helm.sh/release-name: rbd
- meta.helm.sh/release-namespace: rbd
- storageclass.kubernetes.io/is-default-class: "true" # is-default-class
- creationTimestamp: "2023-06-27T11:16:51Z"
- labels:
- app.kubernetes.io/managed-by: Helm
- name: rbd
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。