当前位置: 首页 > news >正文

k8s之Snapshots 详解

Kubernetes Volume Snapshots 详解

在Kubernetes中,Volume Snapshots(卷快照) 是一项关键的存储功能,用于创建持久卷(PV)的时间点副本。这一特性通过CSI(容器存储接口) 实现,并引入了一组新的API资源来管理快照生命周期。本文将详细讲解Kubernetes中的Volume Snapshots相关概念、工作原理及使用方法。

一、核心概念与API资源

1. 卷快照相关资源

Kubernetes通过以下CRD(自定义资源定义)管理卷快照:

VolumeSnapshotClass

类似于StorageClass,定义了创建快照的存储后端配置删除策略

apiVersion: snapshot.storage.k8s.io/v1
kind: VolumeSnapshotClass
metadata:name: csi-snapshot-class
driver: ebs.csi.aws.com  # CSI驱动名称
deletionPolicy: Delete  # 当Snapshot删除时,后端快照也删除
parameters:# 特定于驱动的参数(如备份位置、加密等)
VolumeSnapshot

用户创建的快照请求,指向一个现有的PVC(PersistentVolumeClaim)。

apiVersion: snapshot.storage.k8s.io/v1
kind: VolumeSnapshot
metadata:name: my-pvc-snapshot
spec:volumeSnapshotClassName: csi-snapshot-classsource:persistentVolumeClaimName: my-pvc  # 要快照的PVC名称
VolumeSnapshotContent

由系统自动创建的实际快照内容,类似于PV与PVC的关系。

apiVersion: snapshot.storage.k8s.io/v1
kind: VolumeSnapshotContent
metadata:name: snapcontent-xyz
spec:volumeSnapshotClassName: csi-snapshot-classvolumeSnapshotRef:name: my-pvc-snapshot  # 关联的VolumeSnapshotnamespace: defaultsource:snapshotHandle: aws://us-west-2/snap-12345  # 存储后端的快照ID
status:readyToUse: truerestoreSize: 10Gi

2. CSI 与卷快照

  • CSI(容器存储接口):是Kubernetes与存储系统的标准接口,支持快照功能的CSI驱动需实现以下接口:

    • CreateSnapshot:创建卷快照
    • DeleteSnapshot:删除卷快照
    • ListSnapshots:列出快照
    • DescribeSnapshot:获取快照信息
  • 必备组件

    1. CSI Driver:如AWS EBS CSI Driver、Ceph CSI等
    2. external-snapshotter:Kubernetes官方提供的Sidecar组件,监听VolumeSnapshot资源并调用CSI驱动的快照接口

二、卷快照工作流程

1. 创建快照流程

sequenceDiagramparticipant 用户participant API Serverparticipant VolumeSnapshotControllerparticipant CSI external-snapshotterparticipant CSI Driverparticipant 存储后端用户->>API Server: 创建VolumeSnapshot资源API Server->>VolumeSnapshotController: 触发控制器VolumeSnapshotController->>CSI external-snapshotter: 调用CreateSnapshotCSI external-snapshotter->>CSI Driver: gRPC请求CreateSnapshotCSI Driver->>存储后端: 创建实际快照存储后端-->>CSI Driver: 返回快照IDCSI Driver-->>CSI external-snapshotter: 返回成功CSI external-snapshotter->>API Server: 创建VolumeSnapshotContentAPI Server->>VolumeSnapshot: 更新状态为Ready

2. 从快照恢复卷流程

apiVersion: v1
kind: PersistentVolumeClaim
metadata:name: restored-pvc
spec:storageClassName: ebs-scdataSource:  # 从快照恢复name: my-pvc-snapshotkind: VolumeSnapshotapiGroup: snapshot.storage.k8s.ioaccessModes:- ReadWriteOnceresources:requests:storage: 10Gi

三、关键功能与应用场景

1. 备份与恢复

  • 自动化备份:结合CronJob定期创建VolumeSnapshot
  • 灾难恢复:通过dataSource字段从快照恢复PVC
spec:dataSource:name: my-snapshotkind: VolumeSnapshotapiGroup: snapshot.storage.k8s.io

2. 测试与开发

  • 克隆生产数据:基于生产环境的卷快照创建测试环境
  • 版本回滚:应用升级失败时恢复到之前的状态

3. 数据迁移

  • 跨集群迁移:将快照复制到目标集群并恢复
  • 存储类型转换:例如从AWS EBS迁移到GCE PD

四、配置与使用示例

1. 启用卷快照功能

  1. 安装Snapshot CRDs

    kubectl apply -f https://github.com/kubernetes-csi/external-snapshotter/raw/v6.2.1/client/config/crd/snapshot.storage.k8s.io_volumesnapshotclasses.yaml
    kubectl apply -f https://github.com/kubernetes-csi/external-snapshotter/raw/v6.2.1/client/config/crd/snapshot.storage.k8s.io_volumesnapshots.yaml
    kubectl apply -f https://github.com/kubernetes-csi/external-snapshotter/raw/v6.2.1/client/config/crd/snapshot.storage.k8s.io_volumesnapshotcontents.yaml
    
  2. 部署external-snapshotter

    kubectl apply -f https://github.com/kubernetes-csi/external-snapshotter/raw/v6.2.1/deploy/kubernetes/snapshot-controller/rbac-snapshot-controller.yaml
    kubectl apply -f https://github.com/kubernetes-csi/external-snapshotter/raw/v6.2.1/deploy/kubernetes/snapshot-controller/setup-snapshot-controller.yaml
    
  3. 配置支持快照的CSI驱动(以AWS EBS为例):

    helm install aws-ebs-csi-driver aws-ebs-csi-driver/aws-ebs-csi-driver \--namespace kube-system \--set enableVolumeScheduling=true \--set enableVolumeResizing=true \--set enableVolumeSnapshot=true
    

2. 创建快照示例

  1. 定义VolumeSnapshotClass

    apiVersion: snapshot.storage.k8s.io/v1
    kind: VolumeSnapshotClass
    metadata:name: ebs-snapshot-class
    driver: ebs.csi.aws.com
    deletionPolicy: Retain  # 保留后端快照
    
  2. 创建VolumeSnapshot

    apiVersion: snapshot.storage.k8s.io/v1
    kind: VolumeSnapshot
    metadata:name: my-ebs-snapshot
    spec:volumeSnapshotClassName: ebs-snapshot-classsource:persistentVolumeClaimName: my-ebs-pvc
    
  3. 验证快照状态

    kubectl get volumesnapshot my-ebs-snapshot
    kubectl get volumesnapshotcontent
    

3. 从快照恢复PVC

apiVersion: v1
kind: PersistentVolumeClaim
metadata:name: restored-pvc
spec:storageClassName: ebs-scdataSource:name: my-ebs-snapshotkind: VolumeSnapshotapiGroup: snapshot.storage.k8s.ioaccessModes:- ReadWriteOnceresources:requests:storage: 10Gi
http://www.lryc.cn/news/588835.html

相关文章:

  • Apifox 和 Apipost如何选?2025企业API开发工具选型需求分析及建议
  • 前端打包自动压缩为zip--archiver
  • SpringBoot 2.x→3.0升级实战:Jakarta EE兼容性改造清单
  • Flink双流实时对账
  • GaussDB 数据库架构师修炼(三) 集群管理概览
  • 数据结构--树(1)
  • 同样是“跳转”,为何forward地址栏不变,redirect会变?
  • 20250715给荣品RD-RK3588开发板刷Android14时打开USB鼠标
  • MATLAB知识点总结
  • 物联网设备管理工具实战:用AR运维镜击穿6.8天修复魔咒
  • 构建企业级项目管理全面数字化运营体系︱易趋(蓝云软件)总裁唐智勇
  • 学习C++、QT---26(QT中实现记事本项目实现文件路径的提示、现在我们来学习一下C++类模板、记事本的行高亮的操作的讲解)
  • 【PDF识别改名】使用京东云OCR完成PDF图片识别改名,根据PDF图片内容批量改名详细步骤和解决方案
  • pytorch学习笔记(四)-- TorchVision 物体检测微调教程
  • sundog公司的SilverLining SDK库实现3d动态云层和下雨、下雨、雨夹雪效果
  • 终端安全管理系统为什么需要使用,企业需要的桌面管理软件
  • Java 异常处理详解:从基础语法到最佳实践,打造健壮的 Java 应用
  • Spring Boot目录变文件夹?3步解决!
  • AI大模型训练的云原生实践:如何用Kubernetes指挥千卡集群?
  • ETAS 总线接口 ES582.2
  • Bootstrap-HTML(七)Bootstrap在线图标的引用方法
  • 算法学习笔记:23.贪心算法之活动选择问题 ——从原理到实战,涵盖 LeetCode 与考研 408 例题
  • html语法
  • C++题解(37) 信息学奥赛一本通1318:【例5.3】自然数的拆分
  • 测试tcpdump,分析tcp协议
  • 服务器端安全检测与防御技术概述
  • 力扣25.7.15每日一题——有效单词
  • 微信小程序入门实例_____从零开始 开发一个每天记账的微信小程序
  • 深入理解C++11 std::iota:从原理到实践
  • 深度学习·目标检测和语义分割基础