Questo argomento descrive i passaggi da seguire per configurare il componente del database Cassandra per un'installazione di produzione di Apigee hybrid.
Garantire l'alta disponibilità
I cluster Cassandra richiedono tre zone di disponibilità per mantenere la disponibilità in un ambiente di produzione. Se una zona non è disponibile, le altre continueranno a rispondere alle richieste mentre la zona non disponibile torna online. Se due o più zone non sono disponibili, Cassandra non potrà rispondere alle richieste finché almeno due zone non saranno online. Apigee consiglia di rimettere le zone online entro tre ore per ridurre al minimo il rischio di perdere gli aggiornamenti dei dati.
Configurare le impostazioni di archiviazione di Cassandra
Per un'installazione di produzione di Apigee Hybrid, Google consiglia di aggiungere le seguenti impostazioni di spazio di archiviazione e heap al file delle sostituzioni e di applicarle al cluster:
cassandra: ... replicaCount: 3 storage: storageclass: your-preferred-ssd-storage #If not using default storage for your cluster capacity: 500Gi resources: requests: cpu: 7 memory: 15Gi maxHeapSize: 8192M heapNewSize: 1200M
Applica le modifiche a cassandra con il seguente comando:
helm upgrade datastore apigee-datastore/ \ --namespace apigee \ --atomic \ -f OVERRIDES_FILE.yaml
replicaCount
Il valore di replicaCount
deve essere un multiplo di 3
. Per determinare il valore replicaCount
che preferisci, tieni presente quanto segue:
- Stimare le richieste di traffico per i proxy.
- Esegui un test di carico e fai previsioni ragionevoli sull'utilizzo della CPU.
- Puoi specificare valori
replicaCount
diversi in regioni diverse. - In futuro, potrai espandere
replicaCount
nel file delle sostituzioni.
storageclass
Per la produzione, lo spazio di archiviazione Cassandra deve essere un StorageClass SSD. Imposta il valore di
storageclass
se non utilizzi la classe di archiviazione Kubernetes predefinita per il
cluster. Puoi controllare il StorageClass predefinito con il seguente comando.
kubectl get storageclass
L'output dovrebbe avere il seguente aspetto:
NAME PROVISIONER RECLAIMPOLICY VOLUMEBINDINGMODE ALLOWVOLUMEEXPANSION AGE premium-rwo pd.csi.storage.gke.io Delete WaitForFirstConsumer true 6d23h standard kubernetes.io/gce-pd Delete Immediate true 6d23h standard-rwo (default) pd.csi.storage.gke.io Delete WaitForFirstConsumer true 6d23h
Segui le istruzioni riportate in Configurazione di StorageClass se vuoi modificare la risorsa StorageClass di Kubernetes predefinita.
Per controllare l'impostazione storageclass
corrente, esegui il seguente comando sul cluster:
kubectl get pvc -n NAMESPACE cassandra-data-apigee-cassandra-default-0 -o=jsonpath="{['.spec.storageClassName', '.metadata.annotations.volume\.beta\.kubernetes\.io/storage-class']}"
storageSize
Per le installazioni di produzione, Google consiglia una dimensione dello spazio di archiviazione di almeno 500 Gi (gibibyte). Puoi modificare le dimensioni dello spazio di archiviazione in base alle esigenze del tuo cluster. Consulta le istruzioni in Espandere i volumi Cassandra permanenti per modificare la capacità di archiviazione.
Per controllare l'impostazione della dimensione corrente, esegui il seguente comando sul cluster:
kubectl get pvc -n NAMESPACE cassandra-data-apigee-cassandra-default-0 -o=jsonpath='{.spec.resources.requests.storage}'
cpu
e memory
Per le installazioni di produzione, Google consiglia almeno 7 CPU e un minimo di 15 Gi (gibibyte) per
pod. Quando specifichi cassandra.resources.requests.cpu
e
cassandra.resources.requests.memory
, tieni conto del volume di traffico e delle richieste di CPU e
memoria dei tuoi proxy.
Per controllare l'impostazione corrente della CPU, esegui il seguente comando sul cluster:
kubectl get pods -n NAMESPACE apigee-cassandra-default-0 -o=jsonpath='{.spec.containers[].resources.requests.cpu}'
Per controllare l'impostazione di memoria corrente, esegui il seguente comando sul cluster:
kubectl get pods -n NAMESPACE apigee-cassandra-default-0 -o=jsonpath='{.spec.containers[].resources.requests.memory}'
maxHeapSize
e heapNewSize
Queste proprietà determinano rispettivamente l'heap di memoria massima allocata ai processi Cassandra e l'importo con cui la memoria viene aumentata in megabyte (le dimensioni dell'heap sono specificate in megabyte, non in mebibyte). Per gli ambienti di produzione, Google consiglia i seguenti valori:
maxHeapSize: 8192M
heapNewSize: 1200M
Consulta la documentazione del provider della piattaforma Kubernetes per i valori ottimali delle dimensioni dell'heap.
Per controllare l'impostazione maxHeapSize
corrente, esegui il seguente comando sul cluster:
kubectl get sts -n NAMESPACE apigee-cassandra-default -o=jsonpath='{.spec.template.spec.containers[].env[?(@.name=="MAX_HEAP_SIZE")]}'
Per controllare l'impostazione heapNewSize
corrente, esegui il seguente comando sul cluster:
kubectl get sts -n NAMESPACE apigee-cassandra-default -o=jsonpath='{.spec.template.spec.containers[].env[?(@.name=="HEAP_NEWSIZE")]}'
Per ulteriori informazioni su queste impostazioni delle proprietà, consulta la Guida di riferimento per le proprietà di configurazione.
Utilizza lo spazio di archiviazione SSD per i deployment di produzione
Per il database Cassandra, il runtime ibrido supporta solo l'utilizzo di volumi permanenti creati dinamicamente per archiviare i dati. Le unità a stato solido (SSD) locali non sono supportate.
Se al momento non hai configurato un'unità SSD per Cassandra, devi configurare una definizione di StorageClass basata su un'unità a stato solido (SSD) e impostarla come classe predefinita. Per i passaggi dettagliati, consulta Configurazione di StorageClass.
Segui le istruzioni riportate in Configurazione di StorageClass se vuoi modificare la risorsa StorageClass di Kubernetes predefinita.