Durch das Konfigurieren von Kernelparametern kann AlloyDB Omni Systemarbeitsspeicher und E/A-Ressourcen bei der Verarbeitung hoher Arbeitslasten effizienter nutzen.
Voraussetzungen
Bevor Sie beginnen, muss auf Ihren Kubernetes-Knoten Linux-Kernel 6.1 oder höher ausgeführt werden, insbesondere ein Kernel, der die Flags MADV_COLLAPSE und MADV_POPULATE_WRITE unterstützt. Weitere Informationen zu diesen Flags finden Sie in der Linux madwise Dokumentation.
Empfohlene Kerneleinstellungen auf Kubernetes-Knoten anwenden
In der folgenden Tabelle sind die erforderlichen Kernelparameter und die entsprechenden Werte für Kubernetes-Knoten aufgeführt, auf denen Datenbankcluster-Pods ausgeführt werden:
| Datei | Wert |
|---|---|
/sys/kernel/mm/transparent_hugepage/shmem_enabledInformationen zum gemeinsamen Arbeitsspeicher finden Sie unter Unterstützung für transparente Hugepages |
within_size oder always |
/proc/sys/vm/max_map_countInformationen zur Anzahl der Speicherzuordnungsbereiche, die ein Prozess erstellen kann, finden Sie in der Dokumentation zu /proc/sys/vm |
Größer oder gleich 1073741824 |
So konfigurieren Sie die Kernelparameter auf Ihren Kubernetes-Knoten mit einem DaemonSet:
Wenden Sie Labels auf die Knoten an, auf denen Sie Datenbankcluster ausführen möchten. Folgen Sie dazu der Anleitung unter Label zu einem Knoten hinzufügen.
Erstellen Sie ein DaemonSet, um die Kernelparameter auf den Knoten mit dem Label
LABEL_KEY=LABEL_VALUEfestzulegen:cat << EOF | kubectl apply -f - apiVersion: apps/v1 kind: DaemonSet metadata: name: alloydb-omni-kernel-tuning namespace: DS_NAMESPACE spec: selector: matchLabels: name: alloydb-omni-kernel-tuning template: metadata: labels: name: alloydb-omni-kernel-tuning spec: volumes: - name: host-sys hostPath: path: /sys nodeSelector: LABEL_KEY: "LABEL_VALUE" restartPolicy: Always terminationGracePeriodSeconds: 1 initContainers: - name: enable-thp-mmc image: INIT_IMAGE volumeMounts: - name: host-sys mountPath: /sys securityContext: privileged: true command: ["sh", "-c", "sysctl -w vm.max_map_count=MAX_MAP_COUNT && echo within_size >/sys/kernel/mm/transparent_hugepage/shmem_enabled"] containers: - name: CONTAINER_NAME image: CONTAINER_IMAGE command: ["watch", "-n", "600", "cat", "/sys/kernel/mm/transparent_hugepage/shmem_enabled"] EOFErsetzen Sie Folgendes:
DS_NAMESPACE: der Namespace, in dem Sie das DaemonSet bereitstellen möchten, z. B.default.LABEL_KEY: die Kennung für das Label, z. B.workload.LABEL_VALUE: die Daten, die mit der Kennung für das Label verknüpft sind, z. B.database.INIT_IMAGE: der Name des Images, das für den Init-Container verwendet wird.MAX_MAP_COUNT: die maximale Anzahl der Speicherzuordnungsbereiche, die ein Prozess erstellen kann, z. B.1073741824.CONTAINER_NAME: der Name des Hauptcontainers, z. B.main.CONTAINER_IMAGE: der Name des Images, das für den Hauptcontainer verwendet wird, z. B.latest.
Nachdem Sie das DaemonSet bereitgestellt haben, prüfen Sie mit dem folgenden Befehl, ob sich alle Pods in Ihrem Kubernetes-Cluster im Status
Runningbefinden und ob für jeden Knoten mit dem LabelLABEL_KEY=LABEL_VALUEein Pod vorhanden ist:kubectl get pods -l LABEL_KEY=LABEL_VALUEEine Beispielausgabe sieht so aus:
NAME READY STATUS RESTARTS AGE alloydb-omni-kernel-tuning-2dkwh 1/1 Running 0 22s alloydb-omni-kernel-tuning-pgkbj 1/1 Running 0 19sFühren Sie für jeden der Pods, die nach der Bereitstellung des DaemonSets identifiziert wurden, den folgenden Befehl aus, um zu prüfen, ob das Kernel-Flag erfolgreich angewendet wurde:
kubectl logs POD_NAMEErsetzen Sie
POD_NAMEdurch den Namen des Pods, dessen Logs Sie prüfen möchten.Eine Beispielausgabe sieht so aus:
always [within_size] advise never deny force
Datenbankcluster auf Kubernetes-Knoten mit empfohlenen Kernelparametern ausführen
Wenn Sie Datenbankcluster auf Kubernetes-Knoten mit empfohlenen Kernelparametern bereitstellen möchten, fügen Sie einen nodeAffinity-Abschnitt zu einem der folgenden Abschnitte Ihres Datenbankcluster-Manifests hinzu:
primarySpec.schedulingConfigfür primäre Instanzenspec.schedulingConfigfür Lesepoolinstanzen
nodeaffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
- key: LABEL_KEY
operator: In
values:
- "LABEL_VALUE"
Weitere Informationen zum Ausführen von Datenbankclustern auf bestimmten Kubernetes-Knoten finden Sie unter Knoten mithilfe der Planung einem Datenbankcluster zuweisen.
Anwendung von Kernelparametern prüfen
So prüfen Sie, ob Kernelparameter auf Datenbank-Pods angewendet werden:
Wenn die Hochverfügbarkeit aktiviert ist und
spec.availability.numberOfStandbysauf einen Wert größer als null festgelegt ist, prüfen Sie, ob in der benutzerdefinierten Datenbankressource in der Spalte DBCLUSTERPHASEDBClusterReadyund in der Spalte HAREADYSTATUSTrueangezeigt wird.kubectl get dbcluster -n DBCLUSTER_NAMESPACE DBCLUSTER_NAMEErsetzen Sie Folgendes:
DBCLUSTER_NAME: der Name des Datenbankclusters, den Sie prüfen.DBCLUSTER_NAMESPACE: der Name des spezifischen Namespace, in dem sich Ihr Datenbankcluster befindet.
Eine Beispielausgabe sieht so aus:
NAME PRIMARYENDPOINT PRIMARYPHASE DBCLUSTERPHASE HAREADYSTATUS HAREADYREASON dbcluster-sample 10.29.21.240 Ready DBClusterReady True ReadyListen Sie die Kubernetes-Pods auf, die zum Datenbankcluster gehören:
kubectl get pods -n DBCLUSTER_NAMESPACE -l alloydbomni.internal.dbadmin.goog/dbcluster=DBCLUSTER_NAMEFühren Sie den folgenden Befehl aus, um Informationen zum gemeinsamen Arbeitsspeicher zu prüfen:
kubectl exec -n DBCLUSTER_NAMESPACE POD_NAME -- grep Shmem /proc/meminfoDie Ausgabe muss in allen Einträgen Zahlen enthalten, die nicht null sind.
Eine Beispielausgabe sieht so aus:
Shmem: 126255872 kB ShmemHugePages: 18403328 kB ShmemPmdMapped: 2961408 kBWenn in einem der Einträge
0 kBangezeigt wird, starten Sie den entsprechenden Pod neu:kubectl delete pod -n DBCLUSTER_NAMESPACE POD_NAMEWiederholen Sie die Schritte 1 bis 5, nachdem der Pod den Status
Runninghat.