k8s数据卷(volume)管理

volume数据卷管理

一、volume介绍

用于实现数据的持久化存储

Kubernetes支持多种类型的卷,例如EmptyDir、HostPath、nfs、glusterfs、ceph等

二、emptyDir

创建Pod时,Pod运行的node节点会创建临时卷,并将卷挂载到Pod指定的目录中

临时卷存放目录

/var/lib/kubelet/pods//volumes/kubernetes.io~empty-dir/卷名称

Pod宕机销毁后,该临时卷中的数据会随之被删除

bash 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
    name: test1-deploy
spec:
    replicas: 2
    selector:
         matchLabels:
             app: test1-pod
    template:
       metadata:
           labels:
              app: test1-pod
       spec:
           containers:
           - name: test1-pod
             image: busybox
             imagePullPolicy: IfNotPresent
             command:
             - sleep
             - "3600"
             volumeMounts:
                - name: test1-volume
                  mountPath: /test1
           volumes:
               - name: test1-volume
                 emptyDir: {}

三、hostPath

创建Pod时,Pod运行的node节点会在本地创建目录,并该目录挂载到Pod中

Pod宕机后,宿主机对应目录中的文件不会消失

bash 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
    name: test2-deploy
    labels:
        app: test2-deploy
spec:
    replicas: 2
    selector:
         matchLabels:
             app: test2-pod
    template:
       metadata:
           labels:
              app: test2-pod
       spec:
           containers:
           - name: test2-pod
             image: busybox
             imagePullPolicy: IfNotPresent
             command:
             - sleep
             - "3600"
             volumeMounts:
                - name: test2-volume
                  mountPath: /test1
           volumes:
               - name: test2-volume
                 hostPath:
                    path: /data

四、基于nfs的网络卷

bash 复制代码
apiVersion: apps/v1
kind: Deployment
metadata:
    name: test3-deploy
    labels:
        app: test3-deploy
spec:
    replicas: 2
    selector:
         matchLabels:
             app: test3-pod
    template:
       metadata:
           labels:
              app: test3-pod
       spec:
           containers:
           - name: test3-pod
             image: busybox
             imagePullPolicy: IfNotPresent
             command:
             - sleep
             - "3600"
             volumeMounts:
                - name: test3-volume
                  mountPath: /test1
           volumes:
               - name: test3-volume
                 nfs:
                     server: "192.168.140.11"
                     path: "/data"

五、PV与PVC 持久卷

1、PV、PVC介绍

PV PersistentVolume

后端真实存储空间的映射

PVC PersistentVolumeClain

使用存储空间的申请

使用流程

创建PV标识真实的存储空间

创建PVC发送申请存储空间的请求,K8S集群会自动在PV、PVC间建立映射关系

建立映射关系:

依靠存储空间的大小

依靠PV的访问模式

创建POD时绑定PVC,实现持久化

bash 复制代码
1、创建PV
apiVersion: v1
kind: PersistentVolume
metadata:
    name: nfs-data1
spec:
    capacity:
       storage: 2G
    accessModes:
       - ReadWriteMany
    persistentVolumeReclaimPolicy: Recycle
    nfs:
        server: 192.168.140.13
        path: /data1
相关推荐
阿里云云原生14 小时前
零配置部署顶级模型!函数计算一键解锁 Qwen3.5
云原生
AI攻城狮17 小时前
Kimi Bot + OpenClaw 完整配置指南:5 步实现本地 AI Agent 集成
人工智能·云原生·aigc
AI攻城狮2 天前
RAG Chunking 为什么这么难?5 大挑战 + 最佳实践指南
人工智能·云原生·aigc
可观测性用观测云3 天前
云原生网关 Ingress-Nginx 链路追踪实战:OpenTelemetry 采集与观测云集成方案
nginx·kubernetes
哈里谢顿3 天前
Kubernetes Operator核心概念、实现原理和实战开发
云原生
阿里云云原生4 天前
你的 OpenClaw 真的在受控运行吗?
云原生
阿里云云原生4 天前
5 分钟零代码改造,让 Go 应用自动获得全链路可观测能力
云原生·go
Shanyoufusu124 天前
RKE2 单节点集群安装 Rancher+ 私有镜像仓库搭建 完整教程
云原生
阿里云云原生4 天前
Dify 官方上架 Higress 插件,轻松接入 AI 网关访问模型服务
云原生
AI攻城狮4 天前
OpenClaw Session 管理完全指南:Context 压缩、重置与持久化
人工智能·云原生·aigc