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
相关推荐
mosaicwang4 小时前
创建ipv6 only和ipv6+ip4的k8s集群的注意事项
云原生·容器·kubernetes
孔令飞4 小时前
经典面试题:一文了解常见的缓存问题
缓存·ai·云原生·面试·golang·kubernetes
KubeSphere 云原生6 小时前
基于 KubeKey 3.1.9,快速部署 K8s 1.33.0 高可用集群
云原生·容器·kubernetes
zhuoya_7 小时前
如何更好的理解云计算和云原生?
云原生·云计算
黄交大彭于晏7 小时前
从虚拟化到云原生与Serverless
云原生·serverless
星之尘102119 小时前
“粽”览全局:分布式系统架构与实践深度解析(端午特别版)
分布式·spring cloud·微服务·系统架构·kubernetes·serverless·可用性测试
三金C_C19 小时前
docker 部署 gin
docker·容器·gin
小峰编程20 小时前
rsync服务的搭建
linux·运维·服务器·云原生·centos·服务搭建
长勺20 小时前
docker常见考点
docker·容器
迢迢星万里灬20 小时前
Java求职者面试指南:DevOps技术栈深度解析
java·ci/cd·docker·kubernetes·jenkins·devops