为应用自定义备份和恢复

本页面介绍了如何使用 ProtectedApplication 资源来自定义 Google Distributed Cloud (GDC) 气隙环境中的备份和恢复行为。

本页介绍的步骤是可选的,并非成功配置工作负载备份和恢复所必需的步骤。ProtectedApplication 资源是命名空间中的可选 Kubernetes 资源,用于自定义各个有状态应用的备份和恢复。如果没有 ProtectedApplication 资源,则需遵守以下限制:

  • 您可以将备份和恢复范围粒度限制为命名空间级别。
  • 在执行备份期间,工作负载上不会发生刷新和静默操作。这可能会导致具有多个磁盘的虚拟机在恢复后无法保持崩溃一致性。

ProtectedApplication 资源是可选的 Kubernetes 命名空间资源,用于自定义各个有状态应用的备份和恢复。 ProtectedApplication 资源定义了哪些 Kubernetes 资源属于应用实例。您可以使用 kubectl 命令手动设置专用编排,以便在以下场景中备份和恢复这些应用:

  • 用于识别命名空间中可独立于该命名空间中的其他资源进行备份或恢复的一组资源。ProtectedApplication 是您可以为备份或恢复范围标识的最精细的命名空间实体。
  • ProtectedApplication 属于备份范围时,提供专门的备份编排。具体而言,如果 ProtectedApplication 直接或通过 StatefulSet 中的模板包含 PersistentVolumeClaim (PVC) 资源,您可以在备份卷之前和之后运行 hook。钩子是在应用容器中运行的命令。这些钩子通常用于清空、静默或取消静默操作,并提供应用一致性备份。

准备工作

如要使用 ProtectedApplication 资源,您必须具备以下条件:

  • 您必须先定义 ProtectedApplication 资源,然后才能创建备份方案。如需了解详情,请参阅规划一组备份
  • 必要的身份和访问权限角色:

    • 对于平台管理员 (PA) 用户:
      • 用户集群备份管理员:管理用户集群中的备份资源,例如备份和恢复计划。请让您的组织 IAM 管理员为您授予 User Cluster Backup Admin (user-cluster-backup-admin) 角色。
    • 对于应用运营商 (AO) 用户:
      • 备份创建器:创建手动备份和恢复。请让您的项目 IAM 管理员为您授予 Backup Creator (backup-creator) 角色。
    • 如需了解详情,请参阅角色定义

部署受保护的应用资源

以下示例展示了一个 Deployment 规范,其中包含一个 ProtectedApplication 资源,该资源会在备份期间备份与应用关联的所有资源,并在恢复期间恢复所有资源:

apiVersion: v1
kind: Namespace
metadata:
  name: "applications"
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: protected-application-deployment
  namespace: applications
  labels:
    app: protected
spec:
  selector:
    matchLabels:
      app: nginx
  replicas: 2
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: unprotected-application-deployment
  namespace: applications
  labels:
    app: unprotected
spec:
  selector:
    matchLabels:
      app: nginx
  replicas: 2
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80
---

apiVersion: gkebackup.gke.io/v1
kind: ProtectedApplication
metadata:
  name: protected-application-test
  namespace: applications
spec:
  applicationName: protectedApplication
  resourceSelection:
    type: Selector
    selector:
      matchLabels:
        app: protected
  components:
    - name: protect-application-deployment
      resourceKind: Deployment
      resourceNames:
        - protected-application-deployment
      strategy:
        type: BackupAllRestoreAll

backupScope 中指定 selectedApplications 列表中的 ProtectedApplication。例如:

apiVersion: backup.gdc.goog/v1
kind: BackupPlan
metadata:
  name: protected-application-backupplan-test
  namespace: applications
spec:
  clusterName: "cluster-sample"
  backupSchedule:
    cronSchedule: "*/30 * * * *"
    paused: true
  backupConfig:
    backupScope:
      selectedApplications:
        namespacedNames:
        - name: protected-application-test
          namespace: applications
    backupRepository: "backup-repository"
  retentionPolicy:
    backupDeleteLockDays: 10
    backupRetainDays: 10

此示例包含以下值:

说明
resourceSelection 定义如何识别属于受保护应用的资源:
  • type: 指定以下其中一项:
    • ApplicationName:备份同一命名空间内的 sig-apps 应用。
    • Selector:备份同一命名空间内与给定选择器匹配的资源。
  • applicationName:如果 typeApplicationName,则指定同一命名空间内 sig-apps 应用的名称。
  • selector:如果 typeSelector,则指定用于选择同一命名空间内资源的标签选择器。
components 受保护应用的组件列表,例如部署或有状态集:
  • name:组件的唯一名称。
  • resourceKind:选择 DeploymentStatefulSet
  • resourceNames:用于标识命名空间中 resourceKind 的名称列表。
  • strategy:有关如何备份或恢复此组件的其他详细信息。如需了解详情,请参阅受保护的应用策略

后续步骤