Backup API – Übersicht

Kubernetes wurde für Erweiterbarkeit entwickelt. Sie können einem Kubernetes-Cluster neue APIs wie die Backup API und die GKE Backup Agent API hinzufügen. Diese APIs entsprechen einem einheitlichen API-Modell, dem Kubernetes Resource Model (KRM).

Diese APIs verwenden benutzerdefinierte Kubernetes-Ressourcen und basieren auf dem KRM. Die APIs werden verwendet, um den Lebenszyklus von Sicherungen zu verwalten und Sicherungs-Repositories, ‑Richtlinien und ‑Pläne zu erstellen.

Dienstendpunkte

Die folgende URL ist der API-Endpunkt für die Backup KRM API:

https://MANAGEMENT_API_SERVER_ENDPOINT/apis/backup.gdc.goog/v1

Die folgende URL ist der API-Endpunkt für die GKE Backup Agent API:

https://MANAGEMENT_API_SERVER_ENDPOINT/apis/gkebackup.gke.io/v1

Ersetzen Sie MANAGEMENT_API_SERVER_ENDPOINT durch den Endpunkt des Management API-Servers.

Discovery-Dokument

Verwenden Sie den Befehl kubectl proxy --port=8001, um einen Proxy zum API-Server auf Ihrem lokalen Computer zu öffnen. Von dort aus können Sie über eine der folgenden URLs auf das Discovery-Dokument zugreifen:

  • http://127.0.0.1:8001/apis/backup.gdc.goog/v1
  • http://127.0.0.1:8001/apis/gkebackup.gke.io/v1

Beispiel für die ClusterBackupPlan-Ressource

Hier ist ein Beispiel für eine ClusterBackupPlan-Ressource:

apiVersion: backup.gdc.goog/v1
kind: ClusterBackupPlan
metadata:
  name: backup-plan
  namespace: project-namespace
spec:
  targetCluster:
    targetClusterType: UserCluster
    targetClusterName:
      kind: "Cluster"
      name: "cluster-sample"
  backupSchedule:
    cronSchedule: "*/30 * * * *"
    paused: false
  clusterBackupConfig:
    backupScope:
      selectedNamespaces:
        namespaces: ["nginx"]
    clusterBackupRepositoryName: backup-repository
  retentionPolicy:
    backupDeleteLockDays: 10
    backupRetainDays: 10

Beispiel für die ProtectedApplication-Ressource

Hier ist ein Beispiel für eine ProtectedApplication-Ressource:

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

Beispiel für die ClusterBackupRepository-Ressource

Hier ist ein Beispiel für eine ClusterBackupRepository-Ressource:

apiVersion: backup.gdc.goog/v1
kind: ClusterBackupRepository
metadata:
  name: user-1-user
  namespace: user-1-user-cluster
spec:
    secretReference:
        namespace: "object-storage-secret-ns"
        name: "object-storage-secret"
    endpoint: "https://objectstorage.google.gdch.test"
    type: "S3"
    s3Options:
      bucket: "fully-qualified-bucket-name"
      region: "us-east-1"
      forcePathStyle: true
    importPolicy: "ReadWrite"