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
相关推荐
好吃的肘子3 小时前
ElasticSearch入门详解
java·大数据·elasticsearch·搜索引擎·云原生
alden_ygq3 小时前
Kubernetes生产实战(十九):镜像拉取失败排查处理
云原生·容器·kubernetes
alden_ygq3 小时前
Kubernetes排错(十四):Pod状态异常排查手册
云原生·容器·kubernetes
may_一一6 小时前
Docker宿主机IP获取
tcp/ip·docker·容器
加勒比海涛6 小时前
微服务架构实战:从服务拆分到RestTemplate远程调用
微服务·云原生·架构
alden_ygq7 小时前
Kubernetes生产实战(十四):Secret高级使用模式与安全实践指南
java·安全·kubernetes
掘金-我是哪吒9 小时前
分布式微服务系统架构第128集:elastic-search安装部署
分布式·微服务·云原生·架构·系统架构
小马爱打代码14 小时前
K8S - 蓝绿发布实战 - Argo Rollouts 零停机方案解析
云原生·容器·kubernetes
檀越剑指大厂16 小时前
【Docker系列】docker inspect查看容器部署位置
运维·docker·容器