Il database Cassandra utilizza volumi permanenti creati dinamicamente per archiviare i dati. Per il corretto funzionamento del database, Apigee richiede di configurare una definizione di StorageClass basata su un'unità a stato solido (SSD).
Se al momento non hai configurato l'unità SSD per Cassandra, questo argomento spiega come creare un nuovo StorageClass che utilizzi l'unità SSD e impostarlo come classe predefinita. All'avvio, Cassandra utilizzerà questa classe di archiviazione predefinita.
Modificare la classe di archiviazione predefinita
I passaggi riportati di seguito spiegano come creare una classe StorageClass e impostarla come predefinita. Per ulteriori informazioni, consulta Modificare la classe di archiviazione predefinita nella documentazione di Kubernetes.
- Recupera il nome della classe StorageClass predefinita corrente:
kubectl get sc
Ad esempio:
kubectl get sc
NAME PROVISIONER RECLAIMPOLICY VOLUMEBINDINGMODE ALLOWVOLUMEEXPANSION AGE premium-rwo pd.csi.storage.gke.io Delete WaitForFirstConsumer true 15h standard kubernetes.io/gce-pd Delete Immediate true 15h standard-rwo (default) pd.csi.storage.gke.io Delete WaitForFirstConsumer true 15h - Descrivi la classe di archiviazione denominata
standard-rwo
. Tieni presente che il suo tipo èpd-balanced
:kubectl describe sc standard-rwo
Ad esempio:
kubectl describe sc standard-rwo
Name: standard-rwo IsDefaultClass: Yes Annotations: components.gke.io/layer=addon,storageclass.kubernetes.io/is-default-class=false Provisioner: pd.csi.storage.gke.io Parameters: type=pd-balanced AllowVolumeExpansion: True MountOptions: <none> ReclaimPolicy: Delete VolumeBindingMode: WaitForFirstConsumer Events: <none>
- Crea un nuovo file denominato
storageclass.yaml
. - Aggiungi questo codice al file. Tieni presente che il nome del nuovo corso è
apigee-sc
. Puoi utilizzare il nome che preferisci. Inoltre, tieni presente che il tipo di archiviazione èpd-ssd
:--- kind: StorageClass apiVersion: storage.k8s.io/v1 metadata: name: "apigee-sc" provisioner: pd.csi.storage.gke.io parameters: type: pd-ssd replication-type: none volumeBindingMode: WaitForFirstConsumer allowVolumeExpansion: true
- Applica il nuovo StorageClass al cluster Kubernetes:
kubectl apply -f storageclass.yaml
- Esegui i due comandi seguenti per modificare StorageClass predefinito:
kubectl patch storageclass standard-rwo \ -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"false"}}}'
kubectl patch storageclass apigee-sc \ -p '{"metadata": {"annotations":{"storageclass.kubernetes.io/is-default-class":"true"}}}'
- Esegui questo comando per verificare che la nuova classe di archiviazione predefinita si chiami
apigee-sc
:kubectl get sc
Ad esempio:
kubectl get sc
NAME PROVISIONER RECLAIMPOLICY VOLUMEBINDINGMODE ALLOWVOLUMEEXPANSION AGE apigee-sc (default) kubernetes.io/gce-pd Delete WaitForFirstConsumer true 14h premium-rwo pd.csi.storage.gke.io Delete WaitForFirstConsumer true 15h standard kubernetes.io/gce-pd Delete Immediate true 15h standard-rwo pd.csi.storage.gke.io Delete WaitForFirstConsumer true 15h