Crear capturas de volúmenes

En esta página se explica cómo crear una copia o una instantánea de un volumen de almacenamiento en un momento específico para tu aplicación de contenedor. Una captura de volumen te permite restaurar un volumen a un estado anterior o aprovisionar un volumen nuevo.

Esta página está dirigida a los desarrolladores del grupo de operadores de aplicaciones, que son responsables de crear cargas de trabajo de aplicaciones para su organización. Para obtener más información, consulta Audiencias de la documentación aislada de GDC.

Antes de empezar

Para ejecutar comandos en un clúster de Kubernetes, asegúrate de que tienes los siguientes recursos:

  1. Busca el nombre del clúster de Kubernetes o pregunta a tu administrador de la plataforma cuál es.

  2. Inicia sesión y genera el archivo kubeconfig del clúster de Kubernetes si no tienes uno.

  3. Usa la ruta kubeconfig del clúster de Kubernetes para sustituir KUBERNETES_CLUSTER_KUBECONFIG en estas instrucciones.

Para obtener los permisos necesarios para gestionar las copias de seguridad de volúmenes, pide al administrador de IAM de tu organización que te conceda el rol Administrador de espacio de nombres (namespace-admin) en el espacio de nombres de tu proyecto.

Hacer una captura de volumen

Para hacer una captura de un objeto PersistentVolumeClaim, crea un objeto VolumeSnapshot. El sistema no garantiza la coherencia de los datos. Pausa la aplicación y vacía los datos antes de hacer una captura.

  1. Crea un VolumeSnapshot recurso personalizado:

    kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \
        --namespace NAMESPACE apply -f - <<EOF
    apiVersion: snapshot.storage.k8s.io/v1
    kind: VolumeSnapshot
    metadata:
      name: VOLUME_SNAPSHOT_NAME
    spec:
      source:
        persistentVolumeClaimName: PVC_NAME
    EOF
    

    Haz los cambios siguientes:

    • KUBERNETES_CLUSTER_KUBECONFIG: el archivo kubeconfig del clúster.

    • NAMESPACE: el espacio de nombres del proyecto en el que se va a crear la instantánea del volumen.

    • VOLUME_SNAPSHOT_NAME: el nombre del objeto VolumeSnapshot.

    • PVC_NAME: el nombre del PVC para el que vas a crear una instantánea.

  2. La operación de creación de la instantánea se completa cuando el campo .status.readyToUse pasa a ser true. Puedes usar el siguiente comando para comprobar el estado:

      kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG get volumesnapshot \
        -o custom-columns='NAME:.metadata.name,READY:.status.readyToUse'
    
  3. Actualiza el manifiesto de PVC con la captura del volumen especificada como fuente de datos:

    kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \
        --namespace NAMESPACE apply -f - <<EOF
    apiVersion: v1
    kind: PersistentVolumeClaim
    metadata:
      name: PVC_NAME
    spec:
      dataSource:
        name: VOLUME_SNAPSHOT_NAME
        kind: VolumeSnapshot
        apiGroup: snapshot.storage.k8s.io
      storageClassName: standard-rwo
      accessModes:
        - ReadWriteOnce
     resources:
       requests:
       storage: 10Gi
    EOF
    

    Haz los cambios siguientes:

    • KUBERNETES_CLUSTER_KUBECONFIG: el archivo kubeconfig del clúster.

    • NAMESPACE: el espacio de nombres en el que se encuentra el recurso PVC.

    • PVC_NAME: el nombre del PVC para el que vas a crear una instantánea.

    • VOLUME_SNAPSHOT_NAME: el nombre de la instantánea del volumen.

Siguientes pasos