【CKA 2024】CKA 考前自学 (九)

题目内容

设置配置环境:

[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 之间通过匹配标签和其他属性来进行绑定

常见的操作命令

  1. 创建 PV (通过静态配置创建一个 PV)
$ kubectl create -f pv.yaml
  1. 查看 PV 列表
$ kubectl get pv
  1. 查看 PV 详细信息
$ kubectl describe pv <pv-name>
  1. 查看 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, 请参阅访问模式)。


题目操作步骤

  1. (标准步骤) 进入题目指定集群
$ kubectl config use-context k8s
  1. 上官网复制一份 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
  1. 根据题目要求修改配置文件
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 特性)
  1. 执行配置文件
$ kubectl apply -f pv.yaml

在这里插入图片描述

检查命令

打印全部 PV

$ kubectl get pv

在这里插入图片描述


参考链接:https://kubernetes.io/zh-cn/docs/concepts/storage/persistent-volumes/

请添加图片描述

  • 34
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

安破戎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值