kubernetes:Dynamic Volume
背景动态卷配置的实现基于api group storage.k8s.io中的api object storageclass。群集管理员可以根据需要定义任意多个StorageClass对象,每个对象指定一个卷插件(也称为Provisioner),该插件提供卷和一组参数,以便在配置时传递给该Provisioner。集群管理员可以在集群中定义和公开多种类型的存储(来自相同或不同的存储系统),每个存储都.
背景
动态卷配置的实现基于api group storage.k8s.io中的api object storageclass。群集管理员可以根据需要定义任意多个StorageClass对象,每个对象指定一个卷插件(也称为Provisioner),该插件提供卷和一组参数,以便在配置时传递给该Provisioner。集群管理员可以在集群中定义和公开多种类型的存储(来自相同或不同的存储系统),每个存储都有一组自定义的参数。这种设计还确保最终用户不必担心存储配置的复杂性和细微差别,但仍然能够从多个存储选项中进行选择。
启用Dynamic Volume
根据存储的不通类型创建对应的storageclass ,比如 存储的类型 ,glusterfs ,cephfs ,nfs ,存储的快慢 hdd ,ssd 等等。
hdd StorageClass 定义
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: hdd
provisioner: kubernetes.io/gce-pd
parameters:
type: pd-standard
ssd StorageClass 定义
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
name: ssd
provisioner: kubernetes.io/gce-pd
parameters:
type: pd-ssd
使用Dynamic Volume
通过解析用户pvc定义的 storageClassName字段 ,去匹配对应的StorageClass ,从而获取pv
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: claim1
spec:
accessModes:
- ReadWriteOnce
storageClassName: fast
resources:
requests:
storage: 30Gi
示例中的accessModes =ReadWriteOnce ,表示 一次性读写,当claim 删除的时候,对应的pv也被销毁
Dynamic Volume的默认使用规则
可以在群集上启用动态设置,以便在未指定存储类的情况下动态设置所有声明。群集管理器可以通过以下方式启用此行为:
1.将一个StorageClass对象标记为默认对象;
2 .确保在API服务器上启用了DefaultStorageClass许可控制器。
一句话总结: 可以将一个storageclass 在定义的时候 在Annotation中添加一个键值对:storageclass.kubernetes.io/is-default-class: true,那么此StorageClass就变成默认的StorageClass了。
参考文章:
https://kubernetes.io/docs/concepts/storage/dynamic-provisioning/
https://kubernetes.io/docs/reference/access-authn-authz/admission-controllers/#defaultstorageclass
https://kubernetes.io/docs/reference/access-authn-authz/admission-controllers/#defaultstorageclass
https://kubernetes.io/docs/concepts/storage/persistent-volumes/
更多推荐
所有评论(0)