En esta página, se explica cómo crear y administrar el almacenamiento persistente para las cargas de trabajo de contenedores en tu universo soberano aislado de Google Distributed Cloud (GDC). El almacenamiento persistente proporciona a tu aplicación identidades coherentes y nombres de host estables, independientemente de dónde se programen sus cargas de trabajo.
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. Para obtener más información, consulta Audiences for GDC air-gapped documentation.
Antes de comenzar
Para ejecutar comandos en un clúster de Kubernetes, asegúrate de tener los siguientes recursos:
Ubica el nombre del clúster de Kubernetes o pregúntale al administrador 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_KUBECONFIG
en estas instrucciones.
Para obtener los permisos necesarios para crear un volumen persistente, 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.
Crea un volumen persistente
En las siguientes instrucciones, se muestra cómo crear un volumen con el standard-rwo
StorageClass
de GDC. Para obtener más información sobre los recursos StorageClass
disponibles en GDC, consulta Almacenamiento persistente para contenedores.
Crea un objeto
PersistentVolumeClaim
y configúralo con un modo de accesoReadWriteOnce
y una clase de almacenamientostandard-rwo
:kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \ --namespace NAMESPACE apply -f - <<EOF apiVersion: v1 kind: PersistentVolumeClaim metadata: name: PVC_NAME spec: accessModes: - ReadWriteOnce resources: requests: storage: 10Gi storageClassName: standard-rwo EOF
Reemplaza lo siguiente:
KUBERNETES_CLUSTER_KUBECONFIG
: Es el archivo kubeconfig del clúster.NAMESPACE
: Es el espacio de nombres del proyecto en el que se creará la PVC.PVC_NAME
: Es el nombre del objetoPersistentVolumeClaim
.
Los objetos
PersistentVolume
(PV) se aprovisionan de forma dinámica. Verifica el estado de los PV nuevos en tu clúster de Kubernetes:kubectl get pv --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG
El resultado es similar a este:
NAME CAPACITY ACCESS MODES STATUS CLAIM STORAGECLASS AGE pvc-uuidd 10Gi RWO Bound pvc-name standard-rwo 60s
Configura tus cargas de trabajo de contenedores para que usen el PVC. A continuación, se muestra un ejemplo de un pod
nginx
que usa un PVCstandard-rwo
:kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \ --namespace NAMESPACE apply -f - <<EOF apiVersion: apps/v1 kind: Pod metadata: name: web-server-deployment labels: app: nginx spec: containers: - name: nginx image: nginx volumeMounts: - mountPath: /usr/share/nginx/html name: data volumes: - name: data persistentVolumeClaim: claimName: PVC_NAME EOF
Reemplaza
PVC_NAME
por el PVC que creaste.
Ampliar la capacidad de volumen
Para aumentar la capacidad de un objeto PersistentVolumeClaim
, actualiza el campo spec.resources.storage
a la nueva capacidad. El tamaño máximo admitido del volumen es de 14.5 Ti.
Actualiza el volumen a un tamaño más grande en el archivo de manifiesto del objeto
PersistentVolumeClaim
:kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG \ --namespace NAMESPACE apply -f - <<EOF apiVersion: v1 kind: PersistentVolumeClaim metadata: name: PVC_NAME spec: accessModes: - ReadWriteOnce resources: requests: storage: VOLUME_STORAGE_SIZE EOF
Reemplaza lo siguiente:
KUBERNETES_CLUSTER_KUBECONFIG
: Es el archivo kubeconfig del clúster.NAMESPACE
: Es el espacio de nombres del proyecto en el que existe el recurso de PVC.PVC_NAME
: Es el nombre de la PVC para la que aumentarás el tamaño de almacenamiento.VOLUME_SNAPSHOT_SIZE
: Es la cantidad de tamaño de almacenamiento que se aumentará, como50Gi
.
Verifica el estado de los PV actualizados en tu clúster:
kubectl get pv --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG
¿Qué sigue?
- Descripción general de las cargas de trabajo de contenedores
- Crea cargas de trabajo con estado
- Crea instantáneas de volúmenes