当前位置: 首页 > news >正文

K8S中SC、PV、PVC的理解

存储类(StorageClass)定义了持久卷声明(PersistentVolumeClaim)所需的属性和行为,而持久卷(PersistentVolume)是实际的存储资源,持久卷声明(PersistentVolumeClaim)是 Pod 对持久卷的请求。

简而言之,存储类定义了持久卷的供应方式,持久卷是预先配置的存储资源,持久卷声明是 Pod 对持久卷的请求。存储类通过与 持久卷声明 绑定来创建符合需求的 持久卷,使得 Pod 可以使用持久卷。

从北漂租客眼中的看法:

  • 存储类 相当于我爱*家、链* 等这种租房中介商
  • 持久卷 相当于一套房子(三室两厅、两室三厅、豪华别墅等)
  • 持久卷声明 相当于租客的需求
  • Pod 相当于租客

租客(Pod)想租房子需要找到中介(SC)说出自己的需求(PVC)。中介(SC)根据租客需求(PVC)找到房子(PV)提供给租客使用。

 

在 Kubernetes 中,存储类(StorageClass)、持久卷(PersistentVolume,PV)和持久卷声明(PersistentVolumeClaim,PVC)是用于管理持久化存储的关键组件。下面是它们之间的关系和作用:

  1. 存储类(StorageClass):存储类是用于定义持久卷的供应方式的抽象。它定义了存储卷的类型、访问模式、回收策略等信息。存储类允许管理员为不同的存储需求创建不同的策略,并且可以根据需要动态创建和删除持久卷。当创建 PVC 时,可以指定要使用的存储类,以便 Kubernetes 根据存储类的定义来创建相应的 PV。
  2. 持久卷(PersistentVolume,PV):持久卷是集群中的一块网络存储空间,它独立于 Pod 的生命周期。PV 是由管理员预先配置的,可以是物理存储设备、网络存储或云存储等。PV 具有容量、访问模式和回收策略等属性。PV 可以手动创建,也可以由存储类动态创建。当 PVC 请求一个符合条件的 PV 时,Kubernetes 会根据存储类的定义和可用的 PV 来选择并绑定一个 PV 给 PVC。
  3. 持久卷声明(PersistentVolumeClaim,PVC):持久卷声明是 Pod 对持久卷的请求。PVC 描述了 Pod 对存储的需求,包括容量、访问模式等。PVC 是通过与存储类绑定来创建符合需求的 PV 的一种方式。当创建 PVC 时,可以指定所需的存储类和其他属性,Kubernetes 会根据这些信息来选择并绑定一个合适的 PV 给 PVC。Pod 可以通过 PVC 来访问和使用持久卷。

 

PV/PVC 创建

# PV
apiVersion: v1
kind: PersistentVolume
metadata:annotations:pv.kubernetes.io/provisioned-by: cluster.local/nfs-provisionerfinalizers:- kubernetes.io/pv-protectionname: pvc-8503070c-0b6f-4bb5-aa58-17722872d8ef
spec:accessModes:- ReadWriteManycapacity:storage: 2GiclaimRef:apiVersion: v1kind: PersistentVolumeClaimname: xxx-inbound-collector-xxx-job-start-loadmountOptions:- noresvportnfs:path: /data/nfs-external/xxx-xxx-uat-xxx-inbound-collector-xxx-job-start-load-pvc-8503070c-0b6f-4bb5-aa58-17722872d8efserver: x.32.x.148persistentVolumeReclaimPolicy: DeletestorageClassName: nfs-clientvolumeMode: Filesystem# PVC
apiVersion: v1
kind: PersistentVolumeClaim
metadata:annotations:pv.kubernetes.io/bind-completed: "yes"pv.kubernetes.io/bound-by-controller: "yes"volume.beta.kubernetes.io/storage-provisioner: cluster.local/nfs-provisionercreationTimestamp: "2023-08-29T08:18:23Z"finalizers:- kubernetes.io/pvc-protectionname: xxx-inbound-collector-xxx-job-start-load
spec:accessModes:- ReadWriteManyresources:requests:storage: 2GistorageClassName: nfs-clientvolumeMode: FilesystemvolumeName: pvc-8503070c-0b6f-4bb5-aa58-17722872d8ef

 

http://www.lryc.cn/news/281490.html

相关文章:

  • Agisoft Metashape 基于影像的外部点云着色
  • 图解结算平台:准确高效给商户结款
  • 修改和调试 onnx 模型
  • 不同整数的最少数目和单词直接最短距离
  • 【Microsoft Edge】版本 109.0.1518.55 (正式版本) (64 位) 更新失败解决方案
  • 深度学习笔记(四)——使用TF2构建基础网络的常用函数+简单ML分类实现
  • 大模型学习篇(一):初识大模型
  • uni-app的学习【第二节】
  • matlab行操作快?还是列操作快?
  • 基于SSM的流浪动物救助站
  • 任务13:使用MapReduce对天气数据进行ETL(获取各基站ID)
  • @Controller层自定义注解拦截request请求校验
  • Ceph集群修改主机名
  • 玖章算术NineData通过阿里云PolarDB产品生态集成认证
  • (实战)oracle静默安装runInstaller数据库软件 --参数说明+举例
  • 利用Python的csv(CSV)库读取csv文件并取出某个单元格的内容的学习过程
  • Http三种常见状态码的区别(401、403、500)
  • 分布式锁实现用户锁
  • R语言【paleobioDB】——pbdb_subtaxa():统计指定类群下的子类群数量
  • 3.4 在开发中使用设计模式
  • docker搭建SSH镜像、systemctl镜像、nginx镜像、tomcat镜像
  • [linux] git clone一个repo,包括它的子模块submodule
  • K8S中使用helm安装MinIO
  • 寒假刷题第六天
  • 深度学习笔记(七)——基于Iris/MNIST数据集构建基础的分类网络算法实战
  • Windows启动MongoDB服务报错(错误 1053:服务没有及时响应启动或控制请求)
  • Android Framework 常见解决方案(25-2)定制CPUSET解决方案-system修改及编译部分调整
  • OpenAI推出GPT商店和ChatGPT Team服务
  • 3D建模素材分层渲染怎么操作?
  • SAICP(模拟退火迭代最近点)的实现