k8s存储类型:emptyDir、hostPath、nfs、pvc及存储类storageclass的静态/动态创建pv

Kubernetes存储类型详解

Kubernetes(K8s)提供了多种存储类型,满足不同的存储需求。这些存储类型包括 emptyDirhostPathnfsPersistentVolumeClaim(PVC)以及存储类(StorageClass)的静态和动态创建PersistentVolume(PV)。本文将详细介绍这些存储类型及其配置方法。

一、存储类型概述
1. emptyDir

emptyDir是一种临时存储,当Pod被调度到节点上时,会在节点上创建一个空目录,该目录在Pod的生命周期内存在。当Pod被删除时,emptyDir中的数据也会被删除。主要用于临时数据存储。

复制代码
apiVersion: v1
kind: Pod
metadata:
  name: emptydir-demo
spec:
  containers:
  - name: test-container
    image: busybox
    command: ['sh', '-c', 'sleep 3600']
    volumeMounts:
    - mountPath: /test-emptydir
      name: test-volume
  volumes:
  - name: test-volume
    emptyDir: {}
​
2. hostPath

hostPath允许Pod挂载宿主机文件系统的某个目录到Pod中。这种类型适用于需要直接访问宿主机文件系统的场景,但也带来了安全风险。

复制代码
apiVersion: v1
kind: Pod
metadata:
  name: hostpath-demo
spec:
  containers:
  - name: test-container
    image: busybox
    command: ['sh', '-c', 'sleep 3600']
    volumeMounts:
    - mountPath: /test-hostpath
      name: test-volume
  volumes:
  - name: test-volume
    hostPath:
      path: /data/test
​
3. nfs

nfs允许Pod通过网络文件系统(NFS)访问远程存储。适用于需要共享文件系统的多个Pod之间的数据共享。

复制代码
apiVersion: v1
kind: Pod
metadata:
  name: nfs-demo
spec:
  containers:
  - name: test-container
    image: busybox
    command: ['sh', '-c', 'sleep 3600']
    volumeMounts:
    - mountPath: /test-nfs
      name: test-volume
  volumes:
  - name: test-volume
    nfs:
      server: nfs-server.example.com
      path: /path/to/nfs
​
4. PersistentVolumeClaim(PVC)

PVC是Kubernetes中持久存储的抽象,用户通过声明PVC请求存储资源,而PVC会绑定到满足其需求的PV。PV是管理员预先配置好的存储资源。

创建PV
复制代码
apiVersion: v1
kind: PersistentVolume
metadata:
  name: pv-demo
spec:
  capacity:
    storage: 5Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: /mnt/data
​
创建PVC
复制代码
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-demo
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 5Gi
​
在Pod中使用PVC
复制代码
apiVersion: v1
kind: Pod
metadata:
  name: pvc-demo
spec:
  containers:
  - name: test-container
    image: busybox
    command: ['sh', '-c', 'sleep 3600']
    volumeMounts:
    - mountPath: /test-pvc
      name: test-volume
  volumes:
  - name: test-volume
    persistentVolumeClaim:
      claimName: pvc-demo
​
二、存储类(StorageClass)的使用

存储类(StorageClass)定义了动态创建PV的存储供应策略。管理员可以创建多个StorageClass,用户在创建PVC时指定StorageClass名称,以动态申请存储资源。

创建StorageClass
复制代码
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: standard
provisioner: kubernetes.io/aws-ebs
parameters:
  type: gp2
​
创建PVC时使用StorageClass
复制代码
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: pvc-dynamic
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 10Gi
  storageClassName: standard
相关推荐
r-t-H1 小时前
KVM虚拟化与Docker基础实践-第二章
阿里云·docker·容器
牛奶咖啡133 小时前
k8s容器编排技术实践——OpenEuler安装部署k8s
kubernetes·信创·containerd配置加速器·openeuler安装k8s·k8s的常见安装方式·彻底关闭swap·工作节点使用kubectl
老码观察3 小时前
K8s 容器化部署的宿主机资源规划的踩坑实录
docker·容器·kubernetes
步步为营DotNet3 小时前
深入.NET 11:.NET Aspire 在云原生资源编排与管理的卓越实践
云原生·.net
我是谁??3 小时前
【6】基于 Docker + YOLOv8 的模型部署实战(GTX1660S + Ubuntu22.04)
yolo·docker·容器
密瓜智能4 小时前
HAMi 正式接入 Kubernetes DRA:下一代 GPU 资源模型实践指南
云原生·容器·kubernetes
魔极客4 小时前
1panel面析中Ollama Docker配置错误解析与修复
运维·docker·容器
JAVA社区4 小时前
Java进阶全套教程(八)—— Docker超详细实战详解
java·运维·开发语言·docker·容器·面试·职场和发展
Elastic 中国社区官方博客4 小时前
用于调试 LLM 延迟、成本和 GPU 饱和度的 ES|QL 查询
大数据·人工智能·elasticsearch·搜索引擎·ai·云原生·serverless
我是谁??4 小时前
【5】基于 Docker + YOLOv8 环境实现模型量化(GTX1660S + Ubuntu22.04)
yolo·docker·容器