|-------------------------------|--------------------------|---------------------------------|
| 概念 | 类比 | 作用 |
| NFS服务器 | 家里的共享U盘 (存放在节点上的文件夹) | 提供网络存储空间(比如 /nfs-share) |
| NFS Provisioner | 自动装U盘的机器人 (K8s的自动管理工具) | 当你申请存储时,自动在NFS里创建新U盘 |
| StorageClass (SC) | U盘的类型标签 (比如"高速U盘""普通U盘") | 定义存储的类型和参数(如"用NFS Provisioner") |
| PV (Persistent Volume) | 已装好的U盘 (物理存储设备) | 代表实际存储资源(由Provisioner创建) |
| PVC (Persistent Volume Claim) | 你申请的U盘 (写明"我要5G容量") | 用户向K8s请求存储(K8s自动匹配PV) |
PVC → 触发 NFS Provisioner → 自动创建 PV → 挂载到 Pod(就像你写"我要5G U盘" → 机器人自动装好U盘 → 你插到电脑上)装好后,Pod挂载PVC就像插U盘一样简单!
1. Pod
- 含义:Kubernetes 中最小的运行单元,可以理解为一个或多个容器(如 Docker 容器)的"组合包"。
- 类比:一台虚拟机(VM),但更轻量。你的应用(比如 Web 服务、数据库)就跑在 Pod 里。
- 作用:承载应用进程,是所有工作负载的基础。
✅ 示例:
prometheus-server是一个 Pod,里面运行着 Prometheus 主程序。
2. PV(Persistent Volume)
- 含义 :持久化卷,代表集群中一块真实的存储资源(比如硬盘分区、NFS 目录、云磁盘)。
- 类比:一个已经插到电脑上的 U 盘(物理设备)。
- 作用:提供实际的存储空间,独立于 Pod 生命周期(Pod 删除后数据还在)。
⚠️ PV 是由管理员 预先创建,或者由 Provisioner 自动创建(比如 NFS Provisioner、Longhorn)。
3. PVC(Persistent Volume Claim)
- 含义 :持久化卷声明,是用户对存储的"申请单"。
- 类比:你写一张纸条:"我要一个 10GB 的 U 盘,读写权限"。
- 作用:让 Pod 能够"申请"存储,K8s 会自动匹配一个合适的 PV 绑定给它。
✅ 流程:
Pod → 引用 PVC → PVC 绑定 PV → PV 提供真实存储
4. SC(StorageClass)
- 含义 :存储类,定义了"如何创建 PV"的模板。
- 类比 :U 盘的"类型标签",比如:
- "高速 SSD U 盘"(对应 Longhorn)
- "普通网络共享 U 盘"(对应 NFS)
- 作用 :
- 启用 动态供给(Dynamic Provisioning):当你创建 PVC 时,K8s 自动按 SC 规则创建 PV。
- 不需要管理员手动创建 PV!
✅ 示例:
storageClassName: longhorn # 表示"我要用 Longhorn 创建存储"
5. NFS(Network File System)
- 含义 :一种网络文件系统协议,允许通过网络共享文件夹。
- 类比:公司里的"公共文件服务器",所有人都能访问同一个文件夹。
- 在 K8s 中的作用 :
- 作为后端存储,配合 NFS Provisioner 实现动态创建 PV。
- 适合多 Pod 共享读写的场景(如日志收集、配置同步)。
⚠️ 缺点:性能不如块存储,不适合数据库等高 I/O 应用。
6. Longhorn
- 含义 :一个开源的 分布式块存储系统,专为 Kubernetes 设计。
- 类比:把每台节点的本地硬盘"拼"成一个高性能的云硬盘。
- 在 K8s 中的作用 :
- 提供高性能块存储(类似 AWS EBS、阿里云云盘)。
- 支持快照、备份、多副本(高可用)。
- 适合数据库、有状态应用(如 MySQL、Redis)。
✅ 优势:轻量、易部署、支持单节点(测试环境友好)。
创建测试Pod的流程
创建普通测试Pod主要用于验证应用本身的功能或测试无状态服务,其生命周期短暂,不关心数据存储。
其基本流程是:编写Pod定义文件 -> 部署Pod -> 验证功能 -> 清理资源。
总结:Pod 要存数据 → 写个 PVC 申请 → 指定 StorageClass(NFS 或 Longhorn)→ 系统自动创建 PV → 数据安全持久化!