题目内容
设置配置环境:
[candidate@node-1] $ kubectl config use-context hk8s
Task
创建名为 app-config 的 persistent volume,容量为 1Gi,访问模式为 ReadWriteMany。
volume 类型为 hostPath,位于 /srv/app-config___
考点相关内容分析
PersistentVolume
PersistentVolume(PV)是一种存储资源,它独立于 Pod 存在,并且与 Pod 分离。PV 是集群中的一个资源,它由集群管理员管理,供应给用户和应用程序。PV 可以看作是集群中的一块存储资源,类似于云服务提供商中的存储卷,它们可以被动态地动态地分配给 Pod。PV 通常用于持久存储,以便应用程序可以在重启、删除或重新部署 Pod 后保留其数据。
PersistentVolume 的重要特性和概念:
- 类型: PV 可以支持不同类型的存储,例如网络存储、本地存储等。
- 访问模式: PV 可以有不同的访问模式,例如 ReadWriteOnce(单个节点读写)、ReadOnlyMany(多个节点只读)、和 ReadWriteMany(多个节点读写)。
- 容量和访问策略: PV 可以有不同的容量大小和访问策略,例如回收策略(Reclaim Policy)可以指定当 PV 不再被使用时如何处理资源。
- 静态和动态供应: PV 可以通过静态配置或动态分配来创建。静态供应需要管理员手动配置 PV,而动态供应允许存储后端动态地创建 PV。
- 绑定和声明: PersistentVolumeClaim(PVC)是一个声明,用于请求集群中的 PersistentVolume。PVC 和 PV 之间通过匹配标签和其他属性来进行绑定
常见的操作命令
- 创建 PV (通过静态配置创建一个 PV)
$ kubectl create -f pv.yaml
- 查看 PV 列表
$ kubectl get pv
- 查看 PV 详细信息
$ kubectl describe pv <pv-name>
- 查看 PersistentVolumeClaim 与 PersistentVolume 的绑定情况
$ kubectl get pv,pvc --all-namespaces -o wide
持久卷(PersistentVolume,PV) 是集群中的一块存储,可以由管理员事先制备, 或者使用存储类(Storage Class)来动态制备。 持久卷是集群资源,就像节点也是集群资源一样。PV 持久卷和普通的 Volume 一样, 也是使用卷插件来实现的,只是它们拥有独立于任何使用 PV 的 Pod 的生命周期。 此 API 对象中记述了存储的实现细节,无论其背后是 NFS、iSCSI 还是特定于云平台的存储系统。
持久卷申领(PersistentVolumeClaim,PVC) 表达的是用户对存储的请求。概念上与 Pod 类似。 Pod 会耗用节点资源,而 PVC 申领会耗用 PV 资源。Pod 可以请求特定数量的资源(CPU 和内存)。同样 PVC 申领也可以请求特定的大小和访问模式 (例如,可以挂载为 ReadWriteOnce、ReadOnlyMany、ReadWriteMany 或 ReadWriteOncePod, 请参阅访问模式)。
题目操作步骤
- (标准步骤) 进入题目指定集群
$ kubectl config use-context k8s
- 上官网复制一份 yaml 文件用于修改
打开官网搜索 PV ——> 点击持久卷 ——> 复制示例内容修改
apiVersion: v1
kind: PersistentVolume
metadata:
name: pv0003
spec:
capacity:
storage: 5Gi
volumeMode: Filesystem
accessModes:
- ReadWriteOnce
persistentVolumeReclaimPolicy: Recycle
storageClassName: slow
mountOptions:
- hard
- nfsvers=4.1
nfs:
path: /tmp
server: 172.17.0.2
- 根据题目要求修改配置文件
apiVersion: v1
kind: PersistentVolume
metadata:
name: app-config
spec:
capacity:
storage: 1Gi
accessModes:
- ReadWriteMany
hostPath:
path: /srv/app-config
accessModes 可写参数为
- ReadWriteOnce:卷可以被一个节点以读写方式挂载
- ReadOnlyMany :卷可以被多个节点以只读方式挂载
- ReadWriteMany:卷可以被多个节点以读写方式挂载
- ReadWriteOncePod: 卷可以被单个 Pod 以读写方式挂载 (v1.29 特性)
- 执行配置文件
$ kubectl apply -f pv.yaml
检查命令
打印全部 PV
$ kubectl get pv
参考链接:https://kubernetes.io/zh-cn/docs/concepts/storage/persistent-volumes/