Crea instantáneas de volúmenes

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

Esta página está dirigida a los desarrolladores que forman parte del grupo de operadores de aplicaciones y que son responsables de crear cargas de trabajo de aplicaciones para su organización.

Antes de comenzar

Para ejecutar comandos en el clúster de Kubernetes en equipos físicos preconfigurado, asegúrate de tener los siguientes recursos:

  1. Ubica el nombre del clúster de Kubernetes o pregúntale al administrador de la plataforma cuál es el nombre del clúster.

  2. Accede y genera el archivo kubeconfig para el clúster de Kubernetes si no tienes uno.

  3. Usa la ruta de acceso de kubeconfig del clúster de Kubernetes para reemplazar CLUSTER_KUBECONFIG en estas instrucciones.

Para obtener los permisos necesarios para administrar las instantáneas de volúmenes, pídele al administrador de IAM de tu organización que te otorgue el rol de administrador de espacio de nombres (namespace-admin) en el espacio de nombres de tu proyecto.

Toma una instantánea de volumen

Para tomar una instantánea 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 tomar una instantánea.

  1. Crea un recurso personalizado VolumeSnapshot:

    kubectl --kubeconfig 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
    

    Reemplaza lo siguiente:

    • CLUSTER_KUBECONFIG: Es el archivo kubeconfig del clúster de Kubernetes.

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

    • VOLUME_SNAPSHOT_NAME: Es el nombre del objeto VolumeSnapshot.

    • PVC_NAME: Es el nombre de la PVC para la que creas una instantánea.

  2. La operación de instantánea se completa cuando el campo .status.readyToUse se convierte en true. Puedes usar el siguiente comando para verificar el estado:

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

    kubectl --kubeconfig 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
    

    Reemplaza lo siguiente:

    • CLUSTER_KUBECONFIG: Es el archivo kubeconfig del clúster de Kubernetes.

    • NAMESPACE: Es el espacio de nombres en el que existe el recurso de PVC.

    • PVC_NAME: Es el nombre de la PVC para la que creas una instantánea.

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

¿Qué sigue?