En este documento, 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.
Este documento está dirigido 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. Para obtener más información, consulta Audiences for GDC air-gapped documentation.
Antes de comenzar
Para completar las tareas de este documento, debes tener los siguientes recursos y roles:
Para ejecutar comandos en un clúster de Kubernetes, asegúrate de tener los siguientes recursos:
Busca el nombre del clúster de Kubernetes o pregúntale a un miembro del grupo de administradores de la plataforma cuál es el nombre del clúster.
Accede y genera el archivo kubeconfig para el clúster de Kubernetes si no tienes uno.
Usa la ruta de acceso de kubeconfig del clúster de Kubernetes para reemplazar
KUBERNETES_CLUSTER_KUBECONFIGen estas instrucciones.
Para obtener los permisos necesarios para administrar las instantáneas de volúmenes en un clúster compartido, 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.Para obtener los permisos necesarios para administrar las instantáneas de volúmenes en un clúster estándar, pídele al administrador de IAM de tu organización que te otorgue el rol de desarrollador de clústeres (
cluster-developer) en un clúster estándar.
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.
Crea un recurso personalizado
VolumeSnapshot: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 EOFReemplaza lo siguiente:
KUBERNETES_CLUSTER_KUBECONFIG: Es el archivo kubeconfig del clúster.NAMESPACE: Es el espacio de nombres en el que se creará la instantánea del volumen. En el caso de los clústeres compartidos, debe ser un espacio de nombres del proyecto. En el caso de los clústeres estándares, puede ser cualquier espacio de nombres.VOLUME_SNAPSHOT_NAME: Es el nombre del objetoVolumeSnapshot.PVC_NAME: Es el nombre de la PVC para la que creas una instantánea.
La operación de instantánea se completa cuando el campo
.status.readyToUsese convierte entrue. Puedes usar el siguiente comando para verificar el estado:kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG get volumesnapshot \ -o custom-columns='NAME:.metadata.name,READY:.status.readyToUse'Actualiza el manifiesto del PVC con la instantánea del volumen especificada como una 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 EOFReemplaza lo siguiente:
KUBERNETES_CLUSTER_KUBECONFIG: Es el archivo kubeconfig del clúster.NAMESPACE: Es el espacio de nombres en el que existe el recurso de PVC. En el caso de los clústeres compartidos, debe ser un espacio de nombres del proyecto. En el caso de los clústeres estándares, puede ser cualquier espacio de nombres.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?
- Descripción general de las cargas de trabajo de contenedores
- Crea cargas de trabajo con estado
- Acceder al almacenamiento persistente