【K8s】专题十二(2):Kubernetes 存储之 PersistentVolume

ops/2024/9/24 9:40:56/

本文内容均来自个人笔记并重新梳理,如有错误欢迎指正!

如果对您有帮助,烦请点赞、关注、转发、订阅专栏!


专栏订阅入口

Linux 专栏 | Docker 专栏 | Kubernetes 专栏


往期精彩文章

【Docker】(全网首发)Kylin V10 下 MySQL 容器内存占用异常的解决方法

【Docker】(全网首发)Kylin V10 下 MySQL 容器内存占用异常的解决方法(续)

【Docker】MySQL 源码构建 Docker 镜像(基于 ARM 64 架构)


目录

一、基本介绍

二、资源清单(示例)

1、使用本地存储

2、使用 NFS 存储

3、使用 CSI 存储(如阿里云 NAS)

三、相关说明

1、状态类型(Status)

2、访问模式(AccessModes)

3、回收策略(persistentVolumeReclaimPolicy)


一、基本介绍

在 Kubernetes 中,PersistentVolume(持久化卷,PV)是一种与存储相关的资源对象,可以定义存储容量、访问模式、回收策略、存储插件等信息。PV 具有独立的生命周期,不会随着 Pod 的销毁被删除。PV 的生命周期包括配置、绑定、使用、保护、回收几个阶段。

🔔 PV 对象不属于任何命名空间!


二、工作原理
  • 定义对象:静态模式下,管理员预先在集群中定义 PV 对象,指定其存储容量、访问模式、回收策略、存储插件等配置信息
  • 创建对象:静态模式下,按照管理员预先定义好的资源清单创建 PV 对象;动态模式下,StorageClass 根据 PVC 的申请动态创建 PV 对象
  • 绑定:当一个 PVC 对象创建后,Kubernetes 会寻找一个匹配的 PV 进行绑定,这个过程可以是立即的,也可以是延迟的
  • 使用:PVC 对象与 PV 对象完成绑定后,Pod 就可以通过挂载 PVC 来访问持久化存储。Pod 的资源清单中会包含对 PVC 对象的引用,Kubernetes 负责将与 PVC 对象绑定的 PV 对象挂载到 Pod 的容器中
  • 回收策略:PV 支持三种回收策略:Retain、Recycle、Delete。当 PVC 对象被销毁时,Kubernetes 会根据 PV 的回收策略来处理 PV 对象


三、资源清单(示例)
1、使用本地存储
  • HostPath 方式
apiVersion: v1
kind: PersistentVolume
metadata:name: demo-pv
spec:capacity:storage: 1GiaccessModes:- ReadWriteManypersistentVolumeReclaimPolicy: Recycle / Retain / Delete     # PV 回收策略hostPath:path: /data/nfs
  • Local 方式
apiVersion: v1
kind: PersistentVolume
metadata:name: demo-pv
spec:capacity:storage: 1GiaccessModes:- ReadWriteManypersistentVolumeReclaimPolicy: Recycle / Retain / Delete     # PV 回收策略local:path: /data/nfsnodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: xxxxoperator: Invalues:- xxxx🔔 Local 方式必须要添加 nodeAffinity,否则创建时会报错:
spec.nodeAffinity: Required value: Local volume requires node affinity

2、使用 NFS 存储
apiVersion: v1
kind: PersistentVolume
metadata:name: demo-pv
spec:capacity:storage: 1GiaccessModes:- ReadWriteManypersistentVolumeReclaimPolicy: Recycle / Retain / Delete     # PV 回收策略nfs:server: xx.xx.xx.xx                                 # 指定 NFS 服务器地址path: /data/nfs                                     # 指定 NFS 服务器目录

3、使用 CSI 存储(如阿里云 NAS)
apiVersion: v1
kind: PersistentVolume
metadata:name: demo-pv
spec:capacity:storage: 1GiaccessModes:- ReadWriteManypersistentVolumeReclaimPolicy: Recycle / Retain / Delete     # PV 回收策略csi:driver: com.example.team/csi-drivervolumeHandle: existingVolumeName                      # 与PV 名称保持一致readOnly: falsevolumeAttributes:server: "xxxx"path: "/xxxx"mountOptions:- nolock,tcp,noresvport- vers=3


四、相关说明
1、状态类型(Status)

PV 对象创建后,通常会存在以下几种状态:

  • Available:可用,还未被 PVC 对象绑定
  • Bound:已绑定,已经被 PVC 对象绑定
  • Released:已释放,即 PVC 对象已被删除,但 PV 资源未被集群重新声明(与 Retain 回收方式相关)
  • Failed:已失败,即 PV 对象回收失败

2、访问模式(AccessModes)

在 PV 对象的资源清单中,可以定义以下几种访问模式:

  • ReadWriteOnce:该模式为读写权限,只能被单个 Node 节点挂载

  • ReadOnlyMany:该模式为只读权限,可以被多个 Node 节点挂载

  • ReadWriteMany:该模式为读写权限,可以被多个 Node 节点挂载

3、回收策略(persistentVolumeReclaimPolicy)

在 PV 对象的资源清单中,可以定义以下几种回收策略:

  • Recycle:循环策略,该策略允许保留 PV 对象,并可以再次被新创建的 PVC 对象绑定
  • Retain:保留策略,该策略允许保留 PV 对象,但不可以再次被新创建的 PVC 对象绑定
  • Delete:删除策略(默认),该策略不保留 PV 对象


http://www.ppmy.cn/ops/99011.html

相关文章

@PathVariable:Spring MVC中的路径变量解析

在Spring MVC中,PathVariable注解是一个非常重要的特性,它允许开发者将URL中的一部分作为参数传递给控制器(Controller)的方法。这种机制在处理RESTful风格的API时尤为有用,因为它使得URL更加简洁且富有表达力。本文将…

心得与体会

Loop本地回环 Loop本地回环,通常指的是以127开头的IP地址段(127.0.0.1 – 127.255.255.254),其中127.0.0.1是最常用的一个地址,被称为本地回环地址(Loop back address)。这个地址不属于任何一个…

工厂模式与策略模式:理解与应用

工厂模式与策略模式:理解与应用 1. 引言2. 工厂模式简介2.1 定义2.2 特点2.3 应用场景2.4 工厂模式例子:咖啡制作 3. 策略模式简介3.1 定义3.2 特点3.3 应用场景3.4 策略模式例子:咖啡定价 4. 区别4.1 目的不同4.2 应用场景不同4.3 解决问题不…

开源模型应用落地-qwen2-7b-instruct-LoRA微调模型合并-Axolotl-单机单卡-V100(十)

一、前言 本篇文章将使用Axolotl去合并微调后的模型权重,通过阅读本文,您将能够更好地掌握这些关键技术,理解其中的关键技术要点,并应用于自己的项目中。 二、术语介绍 2.1. LoRA微调 LoRA (Low-Rank Adaptation) 用于微调大型语言模型 (LLM)。 是一种有效的自适应策略,…

easyexcel--导入导出实现自定义格式转换

自定义格式 我们在数据库设计的时候经常会有枚举类型,如0表示普通用户,1表示VIP用户等,这在excel导入的时候,我们会填普通用户而不是0,这样就需要用到自定义格式把普通用户转换成0,我写了一个通用的抽象类…

代码生成:自动化开发

在现代集成开发环境中,智能代码补全和代码生成功能是两个至关重要的组成部分。 智能代码补全利用当前上下文和代码库信息,向程序员推荐合适的代码选项,而代码生成则根据指定输入创建遵循语法和语义规范的代码片段。 许多先进的IDE如Visual St…

【linux中高级命令】

杀进程 1、lsof列出所有打开的文件,‌包括网络连接,‌从而提供关于系统状态的宝贵信息‌ #可以直接查看端口的进程 lsof -i:端口获取到进程,使用kill命令和PID来终止进程 kill -9 [PID]2、列出使用该端口的进程信息,‌包括PID …

UniApp中的Flex布局技巧

随着移动互联网的迅速发展,越来越多的开发者开始使用跨平台技术来开发应用程序。而在跨平台开发里,uniapp是一种非常受欢迎的框架,由于使用uniapp可以快速地开发出同时支持多个平台的应用程序。在uniapp开发中,flex布局是一种非常…